Containers with Ubuntu 12.04.5 LTS are not getting IPv4’s

Since a few weeks one of our servers that is running LXD 6.1-efad198 has a problem with IPv4 addresses. They are not longer configured. IPv6 still works.

And if I have the exact same container(s) on another LXD servers are works fine.

I have tried multiple settings/etc but nothing helped. The firewall/ufw rules are setup as described in the docs. I even tried with disabled ufw and apparmor.

Tried it with a fresh ubuntu:12.04 image. That container does not get an IP too. But with ubuntu:24.04 it does! So something is not playing nice with older version of Ubuntu / Linux.

So then I found out that there is a new fork of lxd: incus.

I hoped that migrating to incus from lxd fixed my IP issue. It did not :frowning:

This is a tshark dump of the lxdbr0 bridge:

root@oev4 ~ # tshark -i lxdbr0 -n
Running as user “root” and group “root”. This could be dangerous.
Capturing on ‘lxdbr0’
** (tshark:2551528) 13:07:20.775129 [Main MESSAGE] – Capture started.
** (tshark:2551528) 13:07:20.775165 [Main MESSAGE] – File: “/tmp/wireshark_lxdbr0YQTRS2.pcapng”

1 0.000000000 fe80::216:3eff:feb7:7cf2 → ff02::16     ICMPv6 90 Multicast Listener Report Message v2
2 0.965008841           :: → ff02::16     ICMPv6 90 Multicast Listener Report Message v2
3 1.291009249           :: → ff02::16     ICMPv6 90 Multicast Listener Report Message v2
4 1.528012677           :: → ff02::16     ICMPv6 90 Multicast Listener Report Message v2
5 1.995019271           :: → ff02::1:ffb7:7cf2 ICMPv6 86 Neighbor Solicitation for fe80::216:3eff:feb7:7cf2
6 2.507016954           :: → ff02::16     ICMPv6 90 Multicast Listener Report Message v2
7 3.019024095 fe80::216:3eff:feb7:7cf2 → ff02::16     ICMPv6 110 Multicast Listener Report Message v2
8 3.019072867 fe80::216:3eff:feb7:7cf2 → ff02::2      ICMPv6 70 Router Solicitation from 00:16:3e:b7:7c:f2
9 3.019480723 fe80::216:3eff:feb8:849e → fe80::216:3eff:feb7:7cf2 ICMPv6 142 Router Advertisement from 00:16:3e:b8:84:9e

10 3.163210162 :: → ff02::1:ffb7:7cf2 ICMPv6 86 Neighbor Solicitation for fd42:749:f51c:e43:216:3eff:feb7:7cf2
11 3.851019116 fe80::216:3eff:feb7:7cf2 → ff02::16 ICMPv6 110 Multicast Listener Report Message v2
12 8.075031988 fe80::216:3eff:feb8:849e → fe80::216:3eff:feb7:7cf2 ICMPv6 86 Neighbor Solicitation for fe80::216:3eff:feb7:7cf2 from 00:16:3e:b8:84:9e
13 8.075077453 fe80::216:3eff:feb7:7cf2 → fe80::216:3eff:feb8:849e ICMPv6 78 Neighbor Advertisement fe80::216:3eff:feb7:7cf2 (sol)
14 13.195997432 fe80::216:3eff:feb7:7cf2 → fe80::216:3eff:feb8:849e ICMPv6 86 Neighbor Solicitation for fe80::216:3eff:feb8:849e from 00:16:3e:b7:7c:f2
15 13.196062444 fe80::216:3eff:feb8:849e → fe80::216:3eff:feb7:7cf2 ICMPv6 78 Neighbor Advertisement fe80::216:3eff:feb8:849e (rtr, sol)
16 19.550697561 00:16:3e:39:1c:e7 → ff:ff:ff:ff:ff:ff ARP 42 Who has 10.0.4.1? Tell 10.14.13.1
17 20.555010655 00:16:3e:39:1c:e7 → ff:ff:ff:ff:ff:ff ARP 42 Who has 10.0.4.1? Tell 10.14.13.1
18 21.579006380 00:16:3e:39:1c:e7 → ff:ff:ff:ff:ff:ff ARP 42 Who has 10.0.4.1? Tell 10.14.13.1

Hi!

Can you summarize which images get an IP address per Linux version of the host, and which ones do not?

Some old runtimes have an issue with newer hosts.

I cannot find the Ubuntu 12.04.4 LTS image here, Index of /releases/12.04.4/release

Can you check whether the same issue is present with Ubuntu 14.04.4 LTS from here, Ubuntu 14.04.5 LTS (Trusty Tahr) so that we can try to reproduce?

yes ubuntu 14.04.5 is working correclty. So it gets an IP adres.
Retried 12.04 from this link: Ubuntu Cloud Images - Ubuntu Server 12.04 LTS (Precise Pangolin)
That does not get an IP.

That directory is empty, Ubuntu Cloud Images - Ubuntu Server 12.04 LTS (Precise Pangolin)

How did you manually import the images into Incus? I am in mid-writing a post on how to import those images in Incus as I think it’s a somewhat involved task. If it’s too easy, I’ll switch to something else.

edit: the page Ubuntu 12.04.5 LTS (Precise Pangolin) takes long to load but in the end it loads, showing the images. This one, is empty, Index of /releases/precise/release

Its not empty but seems not in the structure that incus needs.

I installed it in lxd previously and migrated that to incus.

How can I reinstall it from ubuntu cloud with the link you found?

Regarding the core issue that you are facing, I think it is related to a recent discussion (within last two months) on this forum where old images where using some old style of cgroups vs cgroupsv2 (or AppArmor, or something like that) and this would not allow the instance to get an IPv4 address. Normally when I read the posts on this forum, I click to add a bookmark of such interesting discussions. I just searched my bookmarks in this forum and I could not find that discussion.

Let’s see how to manually add the old Ubuntu 12.04 image as a container in Incus.

We need two files found at Ubuntu 12.04.5 LTS (Precise Pangolin) Note that this site is HTTP and it may stall on some browsers. It’s the -lxd.tar.gz file with metadata and the -root.tar.xz with the rootfs / runtime.
Then, we import to Incus, and finally launch such a container.

wget http://cloud-images-archive.ubuntu.com/releases/precise/release-20170502/ubuntu-12.04-server-cloudimg-amd64-root.tar.xz
wget http://cloud-images-archive.ubuntu.com/releases/precise/release-20170502/ubuntu-12.04-server-cloudimg-amd64-lxd.tar.xz
incus image import ubuntu-12.04-server-cloudimg-amd64-lxd.tar.xz ubuntu-12.04-server-cloudimg-amd64-root.tar.xz --alias ubuntu-12.04-server
incus launch local:ubuntu-12.04-server myinstance-1204

Ok, we got this running. Does it get an IPv4 address?

$ incus list myinstance-1204 -c ns4t
+-----------------+---------+------+-----------+
|      NAME       |  STATE  | IPV4 |   TYPE    |
+-----------------+---------+------+-----------+
| myinstance-1204 | RUNNING |      | CONTAINER |
+-----------------+---------+------+-----------+
$ incus shell myinstance-1204
root@myinstance-1204:~# lsb_release -a
No LSB modules are available.
Distributor ID:	Ubuntu
Description:	Ubuntu 12.04.5 LTS
Release:	12.04
Codename:	precise
root@myinstance-1204:~# dhclient eth0
RTNETLINK answers: Operation not permitted
RTNETLINK answers: Operation not permitted
root@myinstance-1204:~# 

Now, we can reproduce the issue!

I can then just set the network settings manually (using ifconfig, route and add a nameserver in /etc/resolv.conf), and networking works!

$ incus shell myinstance-1204
root@myinstance-1204:~# ifconfig eth0 10.10.10.199
sudo: unable to resolve host myinstance-1204
root@myinstance-1204:~# route add -net default gw 10.10.10.1
root@myinstance-1204:~# cat /etc/resolv.conf 
# Dynamic resolv.conf(5) file for glibc resolver(3) generated by resolvconf(8)
#     DO NOT EDIT THIS FILE BY HAND -- YOUR CHANGES WILL BE OVERWRITTEN
nameserver 10.10.10.1
search incus
root@myinstance-1204:~# host www.google.com
www.google.com has address 172.217.20.68
www.google.com has IPv6 address 2a00:1450:4017:812::2004
root@myinstance-1204:~# 

Super! So for now I will use hard coded IP addresses.
Hope you can fix it in incus soon so that the dhcp way works again.