Skip to content

Commit

Permalink
wip
Browse files Browse the repository at this point in the history
Signed-off-by: Enrique Llorente <[email protected]>
  • Loading branch information
qinqon committed Feb 26, 2024
1 parent 7742f92 commit b5f6b1f
Show file tree
Hide file tree
Showing 10 changed files with 49 additions and 208 deletions.
13 changes: 3 additions & 10 deletions Makefile
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
SHELL := /bin/bash

PULL_SECRET ?= openshift_pull.json
OUT_DIR = $(CURDIR)/build/_output/

all: build-manifests test
Expand All @@ -11,21 +12,13 @@ build-manifests:
./hack/build-manifests.sh ${OUT_DIR}

kcli-run-ocp:
./kcli/run.sh ./kcli/ocp.yaml openshift-pull.json

kcli-add-slb:
./kcli/add-slb.sh

kcli-del-slb:
./kcli/del-slb.sh
./kcli/run.sh ./kcli/ocp.yaml ${PULL_SECRET}

kcli-run-rhcos:
./kcli/run.sh ./kcli/rhcos.yaml openshift-pull.json
./kcli/run.sh ./kcli/rhcos.yaml ${PULL_SECRET}

.PHONY: \
test \
build-manifests \
kcli-run-ocp \
kcli-add-slb \
kcli-del-slb \
kcli-run-rhcos
33 changes: 0 additions & 33 deletions add-slb-nncp.yaml

This file was deleted.

3 changes: 0 additions & 3 deletions custom-config.fcc.tmpl
Original file line number Diff line number Diff line change
Expand Up @@ -7,8 +7,6 @@ storage:
mode: 420
contents:
inline: |
[Match]
OriginalName=*
[Link]
NamePolicy=mac
MACAddressPolicy=persistent
Expand All @@ -18,7 +16,6 @@ storage:
inline: |
[main]
no-auto-default=*
dhcp=dhclient
- path: /usr/local/bin/capture-macs
mode: 0755
contents:
Expand Down
27 changes: 0 additions & 27 deletions del-slb-nncp.yaml

This file was deleted.

20 changes: 6 additions & 14 deletions hack/build-manifests.sh
Original file line number Diff line number Diff line change
Expand Up @@ -4,12 +4,6 @@ set -ex

OUT_DIR=$1

copy_nncp_manifests() {
local nncp_glob="*-slb-nncp.yaml"

cp ${nncp_glob} ${OUT_DIR}
}

build_custom_config() {
local output_fcc=${OUT_DIR}/custom-config.fcc
local output_ign=${OUT_DIR}/custom-config.ign
Expand All @@ -26,23 +20,21 @@ build_custom_config() {
}

build_mco() {
local output_worker_mco=${OUT_DIR}/mco_ovs_workers.yml
local output_supervisor_mco=${OUT_DIR}/mco_ovs_supervisor.yml
local output_worker_mco=${OUT_DIR}/mco_ovs_workers.yml
local output_supervisor_mco=${OUT_DIR}/mco_ovs_supervisor.yml

# Base64 encode the `init-interfaces.sh` file
base64_script_content=$(base64 -w 0 < init-interfaces.sh) && export base64_script_content
# Base64 encode the `init-interfaces.sh` file
export base64_script_content=$(base64 -w 0 < init-interfaces.sh)

# Paste the content into each MCO file
envsubst \$base64_script_content < mco_ovs_workers.yml.tmpl > "${output_worker_mco}"
envsubst \$base64_script_content < mco_ovs_supervisor.yml.tmpl > "${output_supervisor_mco}"
envsubst < mco_ovs_workers.yml.tmpl > "${output_worker_mco}"
envsubst < mco_ovs_supervisor.yml.tmpl > "${output_supervisor_mco}"
}

if [[ ! -d "${OUT_DIR}" ]]; then
mkdir -p "${OUT_DIR}"
fi

copy_nncp_manifests

build_custom_config

build_mco
138 changes: 30 additions & 108 deletions init-interfaces.sh
Original file line number Diff line number Diff line change
Expand Up @@ -3,57 +3,17 @@
set -ex

is_configured() {
[[ $(grep primary /etc/NetworkManager/system-connections/* | wc -l) -ge 1 && $(grep secondary /etc/NetworkManager/system-connections/* | wc -l) -ge 1 ]]
[[ $(nmstatectl show --json bondcnv |jq '.interfaces |length') -eq 1 ]]
}

is_con_exists() {
local con_name=$1
if nmcli -t -g NAME con show | grep -w -q "$con_name"; then
return 0 # true
fi
return 1 # false
read_mac() {
local field=$1
awk -F= "/$field/ {print \$2}" < /boot/mac_addresses | tr '[:lower:]' '[:upper:]'
}

is_con_active() {
local con_name=$1
if nmcli -t -g NAME con show --active | grep -w -q "$con_name"; then
return 0 # true
fi
return 1 # false
}

get_con_name_by_mac_or_device() {
local mac=$(echo $1 | sed -e 's/\\\|://g')
local dev_name=$2
while read -r con; do
if [[ "$(nmcli -g 802-3-ethernet.mac-address c show "${con}" | tr '[A-Z]' '[a-z]' | sed -e 's/\\\|://g')" == "$mac" || $(nmcli -g connection.interface-name c show "${con}") == "${dev_name}" ]]; then
echo "${con}"
break
fi
done <<< "$(nmcli -g NAME c show)"
}

generate_new_con_name() {
local device_name=$1
printf "ethernet-%s-%s" "$device_name" "$RANDOM"
}

set_description() {
find_interface_by_mac() {
local mac=$1
local nic=$2
local description=$3
local connections=$(grep -REl "type=ethernet" /etc/NetworkManager/system-connections | xargs -I{} -- grep -El -i "mac-address=${mac}|interface-name=${nic}" "{}")
IFS=$'\n'
for connection in ${connections}; do
if ! grep nmstate.interface.description "${connection}"; then
echo "" >> "${connection}"
echo "[user]" >> "${connection}"
echo "nmstate.interface.description=${description}" >> "${connection}"
else
sed -i "s/nmstate\.interface\.description=.*/nmstate.interface.description=$description/" "${connection}"
fi
done
unset IFS
nmstatectl show --json |jq -r ".interfaces[] | select(.\"mac-address\"==\"$mac\").name"
}

if [[ ! -f /boot/mac_addresses ]] ; then
Expand All @@ -66,71 +26,33 @@ if is_configured; then
exit 0
fi

primary_mac="$(awk -F= '/PRIMARY_MAC/ {print $2}' < /boot/mac_addresses | tr '[:upper:]' '[:lower:]')"
secondary_mac="$(awk -F= '/SECONDARY_MAC/ {print $2}' < /boot/mac_addresses | tr '[:upper:]' '[:lower:]')"

default_device=""
secondary_device=""
default_connection_name=""
secondary_connection_name=""

for dev in $(nmcli device status | awk '/ethernet/ {print $1}'); do
dev_mac=$(nmcli -g GENERAL.HWADDR dev show "$dev" | sed -e 's/\\//g' | tr '[:upper:]' '[:lower:]')
case $dev_mac in
"${primary_mac}")
default_device="$dev"
default_connection_name=$(get_con_name_by_mac_or_device "$primary_mac" "$dev")
;;
"${secondary_mac}")
secondary_device="$dev"
secondary_connection_name=$(get_con_name_by_mac_or_device "$secondary_mac" "$dev")
;;
*)
;;
esac
done
default_device=$(find_interface_by_mac $(read_mac PRIMARY_MAC))
secondary_device=$(find_interface_by_mac $(read_mac SECONDARY_MAC))

echo -e "default dev: $default_device (CONNECTION.NAME $default_connection_name)\nsecondary dev: $secondary_device (CONNECTION.NAME $secondary_connection_name)"
echo -e "default dev: $default_device \nsecondary dev: $secondary_device"
if [[ -z "$default_device" ]] || [[ -z "$secondary_device" ]]; then
echo "error: primary/secondary device name not found"
exit 1
fi

if eval ! is_con_exists "\"$default_connection_name\""; then
default_connection_name="$(generate_new_con_name "${default_device}")" && export default_connection_name
nmcli con add type ethernet \
conn.interface "${default_device}" \
connection.autoconnect yes \
ipv4.method auto \
con-name "${default_connection_name}" \
802-3-ethernet.mac-address "${primary_mac}"
fi
if eval ! is_con_active "\"$default_connection_name\""; then
nmcli con up "${default_connection_name}"
fi

if eval ! is_con_exists "\"$secondary_connection_name\""; then
secondary_connection_name="$(generate_new_con_name "${secondary_device}")" && export secondary_connection_name
nmcli con add type ethernet \
conn.interface "${secondary_device}" \
connection.autoconnect yes \
ipv4.method disabled \
ipv6.method disabled \
con-name "${secondary_connection_name}" \
802-3-ethernet.mac-address "${secondary_mac}"
fi
if eval ! is_con_active "\"${secondary_connection_name}\""; then
nmcli con mod "${secondary_connection_name}" \
connection.interface-name "${secondary_device}" \
connection.autoconnect yes \
ipv4.method disabled \
ipv6.method disabled \
802-3-ethernet.mac-address "${secondary_mac}"
nmcli con up "${secondary_connection_name}" || /bin/true
fi

set_description "${primary_mac}" "${default_device}" primary
set_description "${secondary_mac}" "${secondary_device}" secondary

nmcli c reload

# We cannot use nmpolicy [1] or /etc/nmstate yet [2]
# [1] https://issues.redhat.com/browse/RHEL-26617
# [2] https://github.com/openshift/machine-config-operator/pull/4212
nmstatectl apply << EOF
interfaces:
- name: bondcnv
type: bond
state: up
ipv4:
enabled: true
dhcp: true
copy-mac-from: $default_device
link-aggregation:
mode: balance-xor
options:
xmit_hash_policy: vlan+srcmac
balance-slb: 1
port:
- $default_device
- $secondary_device
EOF
9 changes: 3 additions & 6 deletions kcli/ocp.yaml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
parameters:
vmrules:
- rhocs-slb-master-0:
- rhocs-slb-ctlplane-0:
cmds:
- echo redhat | passwd --stdin core
cmdline: custom-config macAddressList=52:54:00:f6:80:01,52:54:00:f6:80:02
Expand All @@ -23,11 +23,8 @@ rhocs-slb:
type: kube
kubetype: openshift
domain: redhat.com
version: nightly
tag: '4.10'
masters: 1
tag: '4.14'
ctlplanes: 1
workers: 1
memory: 16384
numcpus: 16
postscripts:
- kcli/deploy-knmstate.sh
6 changes: 3 additions & 3 deletions kcli/run.sh
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
#!/bin/bash -e
#!/bin/bash -ex

tmpdir=$(mktemp -d)

Expand All @@ -20,11 +20,11 @@ patch -p1 < kcli/ignition.patch
export base64_capture_macs_script_content=$(cat capture-macs.sh|base64 -w 0)
envsubst < custom-config.fcc.tmpl > custom-config.fcc
butane < custom-config.fcc > rhocs-slb-worker-0.ign
cp rhocs-slb-worker-0.ign rhocs-slb-master-0.ign
cp rhocs-slb-worker-0.ign rhocs-slb-ctlplane-0.ign

mkdir -p manifests
export base64_script_content=$(cat init-interfaces.sh|base64 -w 0)
envsubst < mco_ovs_workers.yml.tmpl > manifests/mco_ovs_workers.yml
envsubst < mco_ovs_workers.yml.tmpl > manifests/mco_ovs_workers.yml
envsubst < mco_ovs_supervisor.yml.tmpl > manifests/mco_ovs_supervisor.yml

if [[ $0 =~ run.sh ]]; then
Expand Down
4 changes: 2 additions & 2 deletions mco_ovs_supervisor.yml.tmpl
Original file line number Diff line number Diff line change
Expand Up @@ -12,8 +12,8 @@ spec:
units:
- contents: |
[Unit]
Before=kubelet.service
After=NetworkManager.service
Before=ovs-configuration.service
After=NetworkManager-wait-online.service
[Service]
Type=oneshot
ExecStart=/bin/sh /var/init-interfaces.sh
Expand Down
4 changes: 2 additions & 2 deletions mco_ovs_workers.yml.tmpl
Original file line number Diff line number Diff line change
Expand Up @@ -12,8 +12,8 @@ spec:
units:
- contents: |
[Unit]
Before=kubelet.service
After=NetworkManager.service
Before=ovs-configuration.service
After=NetworkManager-wait-online.service
[Service]
Type=oneshot
ExecStart=/bin/sh /var/init-interfaces.sh
Expand Down

0 comments on commit b5f6b1f

Please sign in to comment.