How to support 50K IPv6 addresses on a single machine?


Does anyone know if there is any way to configure 50K "virtual" IPv6 addresses on loopback device in Linux?
The aim is not to add all 50K IPv6 addresses one by one on the loopback/ETH device which will probably mess up the ip table on the system.
In IPv4, I am able to achieve that by specifying the IP address subnet on loopback device (e.g: "ip addr add dev lo").
The same command does not seem to work the same way for IPv6. It only adds a single IPv6 address on loopback device and it automatically adds an "unreachable route" entry on the ipv6 route table for that IPv6 network prefix.

The reason I need this is because I am working on an application which tries to simulate 50K IPv6 addresses on a single Linux box.
The kernel version I am currently using is RHEL

Any help would be greatly appreciated!!



Not that easy FredR

Matt's picture

FredR - I am looking into doing the exact same thing, with simulating thousands of IPv6 addresses on the system without having to create all the addresses, and most importantly so the system doesn't have the overhead of maintaining all of the IP addresses. In IPv4, it is possible to define a subnet on the loopback device in the way that Kai mentioned in his original post. That would allow all IP's from --> to be usable by the system... this is the same thing that I'm looking to accomplish with IPv6... basically to define a usable subnet on the loopback for IPv6, not just a script to generate all the IPv6 addresses as aliases...

any ideas?



brandon's picture

for ip in {yourRangeOfIp}
do sudo /sbin/ifconfig lo inet6 add 2607:f0d0:1002:11::${ip}/64

might work

This seems pretty easy. Pick

FredR's picture

This seems pretty easy. Pick a real interface (eth0 for example). Write a script that adds subinterfaces to eth0 with your ipv6 addresses.

eth0.0 = 1st ipv6 address
eth0.1 = 2nd ipv6 address

and so on. Or you could use the iproute2 "ip" command to add several IPv6 addresses to a single interface:

/sbin/ip addr add 2001:470:X:XXX::XXXX:XXXX:17/64 dev eth0

Chances are, if the addresses are in the same subnet, you won't modify your host's routing table at all. In the above example, ::17 and ::18 would fall under the same /64 subnet.

-- FLR or flrichar is a superfan of Linux Journal, and goofs around in the LJ IRC Channel