Allow container to interop with pre 0.75 containerlab

This commit is contained in:
2026-04-04 05:04:31 +02:00
parent d8369e2c10
commit bb4e55c062
2 changed files with 38 additions and 17 deletions

View File

@@ -9,7 +9,7 @@ ARG VPP_INSTALL_SKIP_SYSCTL=true
ARG REPO=release
EXPOSE 22/tcp
RUN apt-get update && apt-get -y install curl procps tcpdump iproute2 iptables \
iputils-ping net-tools git python3 python3-pip vim-tiny openssh-server \
iputils-ping net-tools git python3 python3-pip vim-tiny nano joe openssh-server \
mtr-tiny traceroute rsync && apt-get clean
# Install VPP - sideload from local debs if --build-context vppdebs=<path> is provided,

View File

@@ -1,12 +1,14 @@
#!/usr/bin/env bash
STARTUP_CONFIG=${STARTUP_CONFIG:="/config/vpp/startup.conf"}
VPPCFG_YAML_FILE=${VPPCFG_YAML_FILE:=/config/vpp/vppcfg.yaml}
VPPCFG_VPP_FILE=${VPPCFG_VPP_FILE:=/config/vpp/config/vppcfg.vpp}
CLAB_VPP_FILE=${CLAB_VPP_FILE:=/config/vpp/config/clab.vpp}
VPPCFG_YAML_FILE=${VPPCFG_YAML_FILE:="/config/vpp/vppcfg.yaml"}
VPPCFG_VPP_FILE=${VPPCFG_VPP_FILE:="/config/vpp/config/vppcfg.vpp"}
CLAB_VPP_FILE=${CLAB_VPP_FILE:="/config/vpp/config/clab.vpp"}
NETNS=${NETNS:="dataplane"}
BIRD_ENABLED=${BIRD_ENABLED:="true"}
BIRD_CONFIG=${BIRD_CONFIG:="/config/bird/bird.conf"}
FRR_ENABLED=${FRR_ENABLED:="false"}
FRR_CONFIG=${FRR_CONFIG:="/config/frr/frr.conf"}
echo "Creating dataplane namespace"
/usr/bin/mkdir -p /etc/netns/$NETNS
@@ -19,26 +21,40 @@ sed -i -e 's,^#PermitRootLogin prohibit-password,PermitRootLogin yes,' /etc/ssh/
sed -i -e 's,^root:.*,root:$y$j9T$kG8pyZEVmwLXEtXekQCRK.$9iJxq/bEx5buni1hrC8VmvkDHRy7ZMsw9wYvwrzexID:20211::::::,' /etc/shadow
/etc/init.d/ssh start
echo "Initializing /config"
for dir in vpp bird frr; do
# TODO(pim): Remove this after containerlab 0.75 is released
if [ -r /etc/vpp/startup.conf ]; then
echo "Detected old containerlab binary - invoking backwards compatible behavior"
STARTUP_CONFIG="/etc/vpp/startup.conf"
VPPCFG_YAML_FILE="/etc/vpp/vppcfg.yaml"
VPPCFG_VPP_FILE="/config/vpp/config/vppcfg.vpp"
CLAB_VPP_FILE="/config/vpp/config/clab.vpp"
BIRD_CONFIG="/etc/bird/bird.conf"
FFR_CONFIG="/etc/frr/frr.conf"
mkdir -p /config/vpp/config/
echo "comment { please upgrade to containerlab 0.75+ }" > /config/vpp/config/manual-pre.vpp
echo "comment { please upgrade to containerlab 0.75+ }" > /config/vpp/config/manual-post.vpp
else
echo "Initializing /config"
for dir in vpp bird frr; do
rsync -av --ignore-existing /etc/$dir/ /config/$dir/
rm -rf /etc/$dir/
ln -s /config/$dir /etc/$dir
done
done
fi
if [ "$BIRD_ENABLED" == "true" ]; then
echo "Starting Bird in $NETNS"
mkdir -p /run/bird /var/log/bird
chown bird:bird /var/log/bird
ROUTERID=$(ip -br a show eth0 | awk '{ print $3 }' | cut -f1 -d/)
sed -i -e "s,.*router id .*,router id $ROUTERID; # Set by container-init.sh," /config/bird/bird.conf
/usr/bin/nsenter --net=/run/netns/$NETNS /usr/sbin/bird -u bird -g vpp -c /config/bird/bird.conf
sed -i -e "s,.*router id .*,router id $ROUTERID; # Set by container-init.sh," $BIRD_CONFIG
/usr/bin/nsenter --net=/run/netns/$NETNS /usr/sbin/bird -u bird -g vpp -c $BIRD_CONFIG
fi
if [ "$FRR_ENABLED" == "true" ]; then
echo "Starting FRRouting in $NETNS"
ROUTERID=$(ip -br a show eth0 | awk '{ print $3 }' | cut -f1 -d/)
sed -i -e "s,^ip router-id .*,ip router-id $ROUTERID," /config/frr/frr.conf
sed -i -e "s,^ip router-id .*,ip router-id $ROUTERID," $FRR_CONFIG
/etc/init.d/frr start
fi
@@ -58,10 +74,15 @@ set interface state $IFNAME up
EOF
done
echo "Generating $VPPCFG_YAML_FILE into $VPPCFG_VPP_FILE"
: > $VPPCFG_VPP_FILE
if [ -r $VPPCFG_YAML_FILE ]; then
if [ -s $VPPCFG_YAML_FILE ]; then
echo "Generating $VPPCFG_YAML_FILE into $VPPCFG_VPP_FILE"
: > $VPPCFG_VPP_FILE
if [ -r $VPPCFG_YAML_FILE ]; then
vppcfg plan --novpp -c $VPPCFG_YAML_FILE -o $VPPCFG_VPP_FILE
fi
else
echo "Generating empty $VPPCFG_VPP_FILE due to missing or empty $VPPCFG_YAML_FILE"
echo "comment { please provide a vppcfg.yaml file }" > $VPPCFG_VPP_FILE
fi
echo "Starting VPP"