Podman : Podman Network2024/05/05 |
Podman コンテナーのネットワーク管理の基本操作です。
|
|
[1] | コンテナー起動時にネットワークを指定しない場合は、デフォルトの [podman] ネットワークが使用されます。 |
# ネットワーク一覧表示 root@dlp:~# podman network ls NETWORK ID NAME DRIVER 2f259bab93aa podman bridge # [podman] ネットワークの詳細表示 root@dlp:~# podman network inspect podman [ { "name": "podman", "id": "2f259bab93aaaaa2542ba43ef33eb990d0999ee1b9924b557b7be53c0b7a1bb9", "driver": "bridge", "network_interface": "podman0", "created": "2024-05-05T04:14:18.141174746Z", "subnets": [ { "subnet": "10.88.0.0/16", "gateway": "10.88.0.1" } ], "ipv6_enabled": false, "internal": false, "dns_enabled": false, "ipam_options": { "driver": "host-local" } } ] # コンテナーのネットワークはデフォルトでは [podman] が使用される root@dlp:~# podman run ubuntu /bin/bash -c "apt-get update; apt-get -y install iproute2; ip route" ..... ..... default via 10.88.0.1 dev eth0 10.88.0.0/16 dev eth0 proto kernel scope link src 10.88.0.18root@dlp:~# podman commit $(podman ps -a | tail -1 | awk '{print $1}') srv.world/iproute
|
[2] | デフォルトの [172.16.16.0/24] 以外のサブネットでコンテナーを起動したい場合は、以下のように実行します。 |
# [network01] ネットワークを [192.168.100.0/24] のサブネットで作成 root@dlp:~# podman network create --subnet 192.168.100.0/24 network01 /etc/cni/net.d/network01.conflist podman network ls NETWORK ID NAME DRIVER f15ddf0ec1e3 network01 bridge 2f259bab93aa podman bridge # [network01] ネットワークを指定してコンテナーを起動 root@dlp:~# podman run --network network01 srv.world/iproute /usr/sbin/ip route default via 192.168.100.1 dev eth0 proto static metric 100 e /usr/sbin/ip route 192.168.100.0/24 dev eth0 proto kernel scope link src 192.168.100.3 # 起動済みのコンテナーに作成したネットワークを接続する場合は以下 root@dlp:~# podman ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 90e6346c401e srv.world/ubuntu-apache2:latest /usr/sbin/apachec... 31 seconds ago Up 31 seconds 0.0.0.0:8081->80/tcp brave_blackwellroot@dlp:~# podman exec 90e6346c401e /usr/sbin/ip route default via 10.88.0.1 dev eth0 proto static metric 100 10.88.0.0/16 dev eth0 proto kernel scope link src 10.88.0.3 # サブネット内の任意の IP アドレスを指定してコンテナーに割り当て root@dlp:~# podman network connect network01 90e6346c401e
podman exec 90e6346c401e /usr/sbin/ip route default via 192.168.100.1 dev eth1 proto static metric 100 default via 10.88.0.1 dev eth0 proto static metric 100 10.88.0.0/16 dev eth0 proto kernel scope link src 10.88.0.3 192.168.100.0/24 dev eth1 proto kernel scope link src 192.168.100.4 # 接続したネットワークを切断する場合は以下 root@dlp:~# podman network disconnect network01 90e6346c401e root@dlp:~# podman exec 90e6346c401e /usr/sbin/ip route default via 10.88.0.1 dev eth0 proto static metric 100 10.88.0.0/16 dev eth0 proto kernel scope link src 10.88.0.3 |
[3] | 作成したネットワークを削除する場合は以下のように実行します。 |
root@dlp:~# podman network ls NETWORK ID NAME DRIVER f15ddf0ec1e3 network01 bridge 2f259bab93aa podman bridge # [network01] を削除 root@dlp:~# podman network rm network01 Error: "network01" has associated containers with it. Use -f to forcibly delete containers and pods: network is being used # 上記のようにコンテナーや Pod と関連付いているネットワークは削除不可 # 強制削除する場合は以下のように [-f] オプションを付加 root@dlp:~# podman network rm -f network01 network01 |
Sponsored Link |
|