FreeBSD 14
Sponsored Link

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
root@dlp:~ #
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_hamilton

root@dlp:~ #
podman exec c8e32238083d ifconfig eth0 | grep inet

        inet 10.88.0.5 netmask 0xffff0000 broadcast 10.88.255.255

root@dlp:~ #
podman network connect 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
        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
関連コンテンツ