Network configurations of LXC containers can happen outside and inside the container. In most of my setups I prefer to use static addressing of the containers using their config file at /var/lib/lxc/containername/config.
But since the latest Debian Bullseye release 11.3 this has stopped working.
By using the lxc-download template (which is installed by default), a new Debian Bullseye container can be created:
 root@host:~# lxc-create -n bullseye -t download -- -d debian -r bullseye -a amd64
[...]
---
You just created a Debian bullseye amd64 (20220411_05:24) container.
To enable SSH, run: apt install openssh-server
No default root or user password are set by LXC.
You could now either configure the IP address inside the container's rootfs or by using the config file. In this case I used the config file /var/lib/lxc/bullseye/config:
root@host:~# cat /var/lib/lxc/bullseye/config | grep net
lxc.net.0.type = veth
lxc.net.0.flags = up
lxc.net.0.link = virbr1
lxc.net.0.ipv4.address = 192.168.1.111/24
lxc.net.0.ipv4.gateway = 192.168.1.1
After starting the container, the container should be listed as started and show the configured static IP address - but for this newly created bullseye container the IP address does not show up:
root@host:~# lxc-start -n bullseye
root@host:~# lxc-ls -f
NAME       STATE   AUTOSTART GROUPS IPV4           IPV6 UNPRIVILEGED       
container1 RUNNING 1         -      192.168.1.110  -    false        
bullseye   RUNNING 1         -      -              -    false 
Another LXC (container1) with Debian Bullseye 11.2 is working just fine, only the newly created Bullseye container with Debian 11.3 is not working.
Note: Actually while pinging the IP (192.168.1.111) the IP responded 1-2 seconds during lxc-start.
You can still attach into the container and everything seems to be running - but no IP address is configured:
 root@host:~# lxc-attach -n bullseye
root@bullseye:~# ip a
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host 
       valid_lft forever preferred_lft forever
2: eth0@if35: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group default qlen 1000
    link/ether 54:52:00:00:12:38 brd ff:ff:ff:ff:ff:ff link-netnsid 0
    inet6 fe80::5652:ff:fe00:1238/64 scope link 
       valid_lft forever preferred_lft forever
Taking a look at the Debian 11.3 release notes shows the following change in the systemd package:
Fix uncontrolled recursion in systemd-tmpfiles [CVE-2021-3997]; demote systemd-timesyncd from Depends to Recommends, removing a dependency cycle; fix failure to bind mount a directory into a container using machinectl; fix regression in udev resulting in long delays when processing partitions with the same label; fix a regression when using systemd-networkd in an unprivileged LXD container
LXD is relying on LXC in the background, so this change might have caused a major regression when configuring static IP addresses in the container's config.
A bug report (Debian #1009351) has been created to address this regression.
Taking a closer look at a Debian 11.2 and a Debian 11.3 LXC container, a difference in the Systemd units related to network can be seen:
Inside a LXC container with Debian 11.2:
root@112:~# cat /etc/debian_version
11.2
root@112:~# systemctl list-units|grep network
  networking.service                  loaded active exited    Raise network interfaces
  network-online.target               loaded active active    Network is Online
  network.target                      loaded active active    Network
Inside a LXC container with Debian 11.3:
root@113:~# cat /etc/debian_version
11.3
root@113:~# systemctl list-units|grep network
  systemd-networkd.service            loaded active running   Network Service
  systemd-networkd.socket             loaded active running   Network Service Netlink Socket
  network.target                      loaded active active    Network
A workaround to get the static IP address configuration outside of the container working again, is to disable the systemd-networkd systemd unit inside the container.
root@host:~# lxc-attach -n bullseye
root@bullseye:~# systemctl list-units|grep network
  systemd-networkd.socket             loaded active listening Network Service Netlink Socket
  network.target                      loaded active active    Network
root@bullseye:~# systemctl stop systemd-networkd
Warning: Stopping systemd-networkd.service, but it can still be activated by:
  systemd-networkd.socket
root@bullseye:~# systemctl disable systemd-networkd
Removed /etc/systemd/system/sockets.target.wants/systemd-networkd.socket.
root@bullseye:~# reboot
A few seconds later, the container is now reachable on the configured static IP address and lxc-ls -f also shows the IP address in the output.
root@host:~# lxc-ls -f
NAME       STATE   AUTOSTART GROUPS IPV4           IPV6 UNPRIVILEGED       
container1 RUNNING 1         -      192.168.1.110  -    false        
bullseye   RUNNING 1         -      192.168.1.111  -    false 
A similar but not the exact same issue also happens with Ubuntu containers. As Ubuntu has introduced netplan as the default network manager, this causes the same problem with missing IP address in LXC containers. A workaround here is to remove the netplan.io package as described here.
 
No comments yet.
 
AWS Android Ansible Apache Apple Atlassian BSD Backup Bash Bluecoat CMS Chef Cloud Coding Consul Containers CouchDB DB DNS Databases Docker ELK Elasticsearch Filebeat FreeBSD Galera Git GlusterFS Grafana Graphics HAProxy HTML Hacks Hardware Icinga Influx Internet Java KVM Kibana Kodi Kubernetes LVM LXC Linux Logstash Mac Macintosh Mail MariaDB Minio MongoDB Monitoring Multimedia MySQL NFS Nagios Network Nginx OSSEC OTRS Observability Office OpenSearch PHP Perl Personal PostgreSQL PowerDNS Proxmox Proxy Python Rancher Rant Redis Roundcube SSL Samba Seafile Security Shell SmartOS Solaris Surveillance Systemd TLS Tomcat Ubuntu Unix VMware Varnish Virtualization Windows Wireless Wordpress Wyse ZFS Zoneminder Linux