Podman : Podman Network2021/03/22 |
Podman コンテナーのネットワーク管理の基本操作です。
|
|
[1] | コンテナー起動時にネットワークを指定しない場合は、デフォルトの [podman] ネットワークが使用されます。 |
# ネットワーク一覧表示 [root@dlp ~]# podman network ls NAME VERSION PLUGINS podman 0.4.0 bridge,portmap,firewall,tuning # [podman] ネットワークの詳細表示 [root@dlp ~]# podman network inspect podman [ { "cniVersion": "0.4.0", "name": "podman", "plugins": [ { "bridge": "cni-podman0", "hairpinMode": true, "ipMasq": true, "ipam": { "ranges": [ [ { "gateway": "10.88.0.1", "subnet": "10.88.0.0/16" } ] ], "routes": [ { "dst": "0.0.0.0/0" } ], "type": "host-local" }, "isGateway": true, "type": "bridge" }, { "capabilities": { "portMappings": true }, "type": "portmap" }, { "type": "firewall" }, { "type": "tuning" } ] } ] # コンテナーのネットワークはデフォルトでは [podman] が使用される [root@dlp ~]# podman run centos:stream8 /usr/sbin/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.7 |
[2] | デフォルトの [10.88.0.0/16] 以外のサブネットでコンテナーを起動したい場合は、以下のように実行します。 |
# [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 NAME VERSION PLUGINS podman 0.4.0 bridge,portmap,firewall,tuning network01 0.4.0 bridge,portmap,firewall,tuning # [network01] ネットワークを指定してコンテナーを起動 [root@dlp ~]# podman run --network network01 centos:stream8 /usr/sbin/ip route default via 192.168.100.1 dev eth0 192.168.100.0/24 dev eth0 proto kernel scope link src 192.168.100.4 # 起動済みのコンテナーに作成したネットワークを接続する場合は以下 [root@dlp ~]# podman ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES d5681a6ca157 srv.world/centos-httpd /usr/sbin/apachec... 5 seconds ago Up 4 seconds ago 0.0.0.0:8081->80/tcp kind_swirles[root@dlp ~]# podman exec d5681a6ca157 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.9 # サブネット内の任意の IP アドレスを指定してコンテナーに割り当て [root@dlp ~]# podman network connect network01 d5681a6ca157
podman exec d5681a6ca157 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.9 192.168.100.0/24 dev eth1 proto kernel scope link src 192.168.100.5 # 接続したネットワークを切断する場合は以下 [root@dlp ~]# podman network disconnect network01 d5681a6ca157 [root@dlp ~]# podman exec d5681a6ca157 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.9 |
[3] | 作成したネットワークを削除する場合は以下のように実行します。 |
[root@dlp ~]# podman network ls NAME VERSION PLUGINS podman 0.4.0 bridge,portmap,firewall,tuning network01 0.4.0 bridge,portmap,firewall,tuning # [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 |
|