Usiłuję teraz przypisać statyczny adres IP 172.17.0.1 podczas uruchamiania kontenera Docker.
Używam portu 2122 jako portu ssh tego kontenera, dzięki czemu ten kontener może nasłuchiwać portu 2122.
sudo docker run -i -t -p 2122:2122 ubuntu
To polecenie uruchomi kontener Docker z losowym adresem IP, takim jak 172.17.0.5, ale muszę przypisać konkretny adres IP do kontenera.
Poniższy skrypt powłoki odwołuje się do dokumentacji Docker w zaawansowanych ustawieniach sieciowych.
pid=$(sudo docker inspect -f '{{.State.Pid}}' <container_name> 2>/dev/null)
sudo rm -rf /var/run/netns/*
sudo ln -s /proc/$pid/ns/net /var/run/netns/$pid
sudo ip link add A type veth peer name B
sudo brctl addif docker0 A
sudo ip link set A up
sudo ip link set B netns $pid
sudo ip netns exec $pid ip link set eth0 down
sudo ip netns exec $pid ip link delete eth0
sudo ip netns exec $pid ip link set dev B name eth0
sudo ip netns exec $pid ip link set eth0 address 12:34:56:78:9a:bc
sudo ip netns exec $pid ip link set eth0 down
sudo ip netns exec $pid ip link set eth0 up
sudo ip netns exec $pid ip addr add 172.17.0.1/16 dev eth0
sudo ip netns exec $pid ip route add default via 172.17.42.1
Ten skrypt powłoki przypisze statyczny adres IP 172.17.0.1 i link do grzywny na świecie. Ale ilekroć próbuję ssh do tego kontenera z mojego lokalnego, to nie działa. Jaki problem prawdopodobnie napotkałem?