Podman : Network 基本操作2024/03/05 |
Podman コンテナーのネットワーク管理の基本操作です。
|
|
[1] | コンテナー起動時にネットワークを指定しない場合は、デフォルトの [podman] ネットワークが使用されます。 |
# ネットワーク一覧表示 root@dlp:~ # podman network ls NETWORK ID NAME DRIVER 2f259bab93aa podman bridge b5a6ed25b2be root_default bridge # [podman] ネットワークの詳細表示 root@dlp:~ # podman network inspect podman [ { "name": "podman", "id": "2f259bab93aaaaa2542ba43ef33eb990d0999ee1b9924b557b7be53c0b7a1bb9", "driver": "bridge", "network_interface": "cni-podman0", "created": "2024-03-05T08:31:05.927897408+09:00", "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" } } ]root@dlp:~ # podman images REPOSITORY TAG IMAGE ID CREATED SIZE localhost/freebsd-nginx latest a0a053cc78a3 5 days ago 1.17 GB localhost/freebsd-httpd latest add46dedb2b7 5 days ago 1.44 GB localhost/freebsd-base latest 2527bfa5eeb4 6 days ago 1.05 GB quay.io/centos/centos stream9 ce3ac91d4020 2 weeks ago 161 MB docker.io/library/ubuntu latest 3db8720ecbf5 2 weeks ago 80.4 MB # コンテナーのネットワークはデフォルトでは [podman] が使用される root@dlp:~ # podman run localhost/freebsd-base ifconfig eth0 | grep inet inet 10.88.0.4 netmask 0xffff0000 broadcast 10.88.255.255 |
[2] | デフォルトの [10.88.0.0/16] 以外のサブネットでコンテナーを起動したい場合は、以下のように実行します。 |
# [network01] ネットワークを [192.168.100.0/24] のサブネットで作成 root@dlp:~ # podman network create --subnet 192.168.100.0/24 network01 network01 podman network ls NETWORK ID NAME DRIVER 5370c5e15abf network01 bridge 2f259bab93aa podman bridge b5a6ed25b2be root_default bridge # [network01] ネットワークを指定してコンテナーを起動 root@dlp:~ # podman run --network network01 localhost/freebsd-base ifconfig eth0 | grep inet inet 192.168.100.2 netmask 0xffffff00 broadcast 192.168.100.255 # 起動済みのコンテナーに作成したネットワークを接続する場合は以下 root@dlp:~ # podman ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES c8e32238083d localhost/freebsd-httpd:latest /usr/local/sbin/h... 7 seconds ago Up 7 seconds 0.0.0.0:8081->80/tcp condescending_hamiltonroot@dlp:~ # podman exec c8e32238083d ifconfig eth0 | grep inet inet 10.88.0.5 netmask 0xffff0000 broadcast 10.88.255.255
root@dlp:~ #
root@dlp:~ # podman network connect network01 c8e32238083d
podman exec c8e32238083d ifconfig | grep -w inet inet 127.0.0.1 netmask 0xffffff00 inet 10.88.0.5 netmask 0xffff0000 broadcast 10.88.255.255 inet 192.168.100.3 netmask 0xffffff00 broadcast 192.168.100.255 # 接続したネットワークを切断する場合は以下 root@dlp:~ # podman network disconnect network01 c8e32238083d root@dlp:~ # podman exec c8e32238083d ifconfig | grep -w inet inet 127.0.0.1 netmask 0xffffff00 inet 10.88.0.5 netmask 0xffff0000 broadcast 10.88.255.255 |
[3] | 作成したネットワークを削除する場合は以下のように実行します。 |
root@dlp:~ # podman network ls NETWORK ID NAME DRIVER 5370c5e15abf network01 bridge 2f259bab93aa podman bridge b5a6ed25b2be root_default 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 |
|