「設定 - Podman Compose」の版間の差分
67行目: | 67行目: | ||
<syntaxhighlight lang="yaml"> | <syntaxhighlight lang="yaml"> | ||
version: '<Composeファイルのバージョン (docker-compose.ymlのバージョンと同じ)>' # 例: '3' | version: '<Composeファイルのバージョン (docker-compose.ymlのバージョンと同じ)>' # 例: '3' | ||
networks: | |||
frontend: | |||
driver: <ネットワークのドライバを指定> # bridge, overlay, macvlan等を指定する | |||
backend: | |||
driver: <ネットワークのドライバを指定> # bridge, overlay, macvlan等を指定する | |||
external: <既存の外部ネットワークを指定> | |||
driver_opts: <ドライバに関連する追加のオプションを指定> | |||
ipam: # IPアドレスの管理に関連する設定を指定する | |||
driver: default # IPアドレス管理のドライバを指定する | |||
config: # driverセクションに指定したドライバに関する設定を指定する | |||
- subnet: "<サブネットマスク>" # 例: 172.18.0.0/16 | |||
# networksセクションの説明: | |||
# 上記の例では、backendネットワークに対しては、ipamセクションでサブネットを指定している。 | |||
# これにより、ネットワーク内のコンテナに対して、手動でIPアドレスを指定することができる。 | |||
services: | services: | ||
<コンテナ名 1 (任意の名前)>: # 例: sample1 | <コンテナ名 1 (任意の名前)>: # 例: sample1 | ||
95行目: | 112行目: | ||
- <コンテナ名> # 例: sample1 | - <コンテナ名> # 例: sample1 | ||
</syntaxhighlight> | </syntaxhighlight> | ||
<br><br> | |||
== container-compose.ymlファイルの検証 == | |||
docker-compose.ymlファイルと同様、ファイルの検証は<code>podman-compose -f <container-compose.ymlファイルのパス> config</code>コマンドを実行する。<br> | |||
container-compose.ymlファイルと同階層のディレクトリで実行する場合、または、環境変数<code>COMPOSE_FILE</code>がcontainer-compose.ymlファイルを指している場合は、<br> | |||
<code>-f <container-compose.ymlファイル></code>の部分を省略することができる。<br> | |||
podman-compose -f <container-compose.ymlファイルのパス> config | |||
# または | |||
podman-compose config # コマンドを実行しているカレントディレクトリと同階層のディレクトリにcontainer-compose.ymlファイルが存在する場合 | |||
<br><br> | <br><br> | ||
2024年2月15日 (木) 09:16時点における版
概要
podman compose
コマンドは、docker-composeやpodman-composeのような外部のComposeプロバイダの薄いラッパーである。
つまり、podman compose
はConpose機能を実装する別のツールを実行するが、Composeプロバイダがローカルの Podmanソケットと透過的に通信できるように環境を設定する。
指定したオプション、コマンド、引数は直接composeプロバイダに渡される。
デフォルトのComposeプロバイダは、docker-composeとpodman-composeである。
両方ともインストールされている場合は、docker-composeが優先される。
なぜなら、docker-composeはCompose仕様のオリジナルの実装であり、サポートされているプラットフォーム (Linux、MacOS、Windows) で広く使用されているからである。
デフォルトの挙動を変更する場合や、選択したプロバイダのカスタムインストールパスが必要な場合は、containers.confファイルのcompose_provider
フィールドを変更する必要がある。
また、環境変数PODMAN_COMPOSE_PROVIDER
を設定して変更することもできる。
Podman Composeのインストール
パッケージ管理システムからインストール
# RHEL sudo dnf install podman-compose # SUSE sudo zypper install python3-podman-compose
PyPIからインストール
# Python3のルートディレクトリにインストールする場合 pip3 install podman-compose python-dotenv PyYAML # Python3のユーザディレクトリにインストールする場合 pip3 install --user podman-compose python-dotenv PyYAML # GithubからPodman Composeを直接インストールする場合 pip3 install https://github.com/containers/podman-compose/archive/devel.tar.gz pip3 install python-dotenv PyYAML
ソースコードからインストール
まず、PyYAMLおよびPython-DotEnvをインストールする。
パッケージ管理システムからPyYAMLおよびPython-DotEnvをインストールする場合、依存関係が多すぎるため、PyPIからインストールすることを推奨する。
pip3 install --user python-dotenv PyYAML
もし、CNIネットワークを使用する場合は、Podman DNSname Pluginをインストールする。
ただし、2023年以降、Podman DNSname Pluginの開発は止まっているため、netavarkとaardvark-dnsを使用することを推奨する。
# Podman DNSname Pluginのインストール git clone https://github.com/containers/dnsname.git cd dnsname make -j $(nproc) PREFIX=<Podmanのインストールディレクトリ> make install PREFIX=<Podmanのインストールディレクトリ> # netavarkおよびaardvark-dnsをパッケージ管理システムからインストール sudo zypper install netavark aardvark-dns
Podman ComposeのGithubから、ソースコードをダウンロードする。
git clone https://github.com/containers/podman-compose.git -b stable
Podman Composeをビルドおよびインストールする。
export PYTHONPATH="/<Podmanのインストールディレクトリ>/lib/python<Pythonのバージョン>/site-packages:$PYTHONPATH" python3 ./setup.py build python3 ./setup.py install --prefix=<Podmanのインストールディレクトリ>
~/.profileファイル等に、環境変数PYTHONPATH
を設定する。
export PYTHONPATH="/<Podmanのインストールディレクトリ>/lib/python<Pythonのバージョン>/site-packages:$PYTHONPATH"
container-compose.ymlファイル
version: '<Composeファイルのバージョン (docker-compose.ymlのバージョンと同じ)>' # 例: '3'
networks:
frontend:
driver: <ネットワークのドライバを指定> # bridge, overlay, macvlan等を指定する
backend:
driver: <ネットワークのドライバを指定> # bridge, overlay, macvlan等を指定する
external: <既存の外部ネットワークを指定>
driver_opts: <ドライバに関連する追加のオプションを指定>
ipam: # IPアドレスの管理に関連する設定を指定する
driver: default # IPアドレス管理のドライバを指定する
config: # driverセクションに指定したドライバに関する設定を指定する
- subnet: "<サブネットマスク>" # 例: 172.18.0.0/16
# networksセクションの説明:
# 上記の例では、backendネットワークに対しては、ipamセクションでサブネットを指定している。
# これにより、ネットワーク内のコンテナに対して、手動でIPアドレスを指定することができる。
services:
<コンテナ名 1 (任意の名前)>: # 例: sample1
image: <イメージ (リポジトリ:タグ) を指定する> # イメージからコンテナを生成する場合、imageを指定
command:
<コンテナ起動時に実行するコマンド> # 例: --default-authentication-plugin=mysql_native_password>
volumes: # ホストとコンテナでファイルを同期する場合等
- <ホスト側のパス 1:コンテナのパス 1> # 例: /tmp/mysql/mysql_data:/var/lib/mysql
- <ホスト側のパス 2:コンテナのパス 2>
ports: # ポート転送 (ポートフォワーディング) を行う場合
- <ホスト側のポート 1:コンテナのポート 1> # 例: 63306:3306
- <ホスト側のポート 2:コンテナのポート 2>
environment: # 環境変数を指定する場合
<環境変数名 1: 環境変数値> # 例: MYSQL_ROOT_PASSWORD: password
<環境変数名 2: 環境変数値> # 例: MYSQL_PORT: 3306
<コンテナ名 2 (任意の名前) 例: sample2)>:
build: <Containerfileのファイルパス> # Containerfileを使用する場合、buildを指定
volumes: # ホストとコンテナでファイルを同期する場合等
- <ホスト側のパス:コンテナのパス>
ports: # ポート転送 (ポートフォワーディング) を行う場合
- <ホスト側のポート:コンテナのポート>
environment: # 環境変数を指定する場合
<環境変数名 1: 環境変数値>
<環境変数名 2: 環境変数値>
<環境変数名 3: 環境変数値>
depends_on: # 依存関係を設定する場合 (他のコンテナと連携する場合)
- <コンテナ名> # 例: sample1
container-compose.ymlファイルの検証
docker-compose.ymlファイルと同様、ファイルの検証はpodman-compose -f <container-compose.ymlファイルのパス> config
コマンドを実行する。
container-compose.ymlファイルと同階層のディレクトリで実行する場合、または、環境変数COMPOSE_FILE
がcontainer-compose.ymlファイルを指している場合は、
-f <container-compose.ymlファイル>
の部分を省略することができる。
podman-compose -f <container-compose.ymlファイルのパス> config # または podman-compose config # コマンドを実行しているカレントディレクトリと同階層のディレクトリにcontainer-compose.ymlファイルが存在する場合
Composeコマンド
container-compose.ymlファイルを実行するには、podman-compose -d
コマンドで実行する必要がある。
Composeコマンドは、container-compose.ymlファイルが存在するディレクトリで行う。
もし、別のディレクトリに存在するcontainer-compose.ymlファイルを指定する場合は、-f
オプションを付加する。
podman-compose <コマンド> -f <container-compose.ymlファイルのパス>
サービスイメージの確認
podman-compose images
サービスイメージの作成
サービスイメージのビルドを実行する。
container-compose.ymlファイルにimage:
が記述されている場合、そのイメージ名がローカルに存在しなければ、リモートからプルする。
container-compose.ymlファイルにimage:
が記述されていない場合、build
に記述されているパスのContainerfileを使用して、コンテナイメージを構築する。
podman-compose build
リモートからサービスイメージを取得
リモートからコンテナイメージを取得する。
podman-compose pull
サービスの確認
podman-compose ps
サービスの作成
構築されたサービスイメージからサービスを作成する。
また、作成直後のサービスは停止している。
podman-compose create
サービスの実行
サービスを作成して起動する。
-d
オプションを付加することにより、バックグラウンドで実行することができる。
また、--build
オプションを付加することにより、起動前にイメージを構築することもできる。
podman-compose up # バックグラウンドで実行する場合 podman-compose up -d # サービスイメージを構築してサービスを実行する場合 podman-compose up -d --build
サービスの起動
停止中のサービスを起動する。
podman-compose start
サービス再起動
サービスを再起動する。
podman-compose restart
サービスの停止
起動中のサービスを停止する。
podman-compose stop
サービスの削除
container-compose.ymlファイルに記述されているサービスからコンテナを停止して、そのコンテナとネットワークを削除する。
--rmi all
オプションを付加することにより、サービスイメージも削除することができる。
podman-compose down # サービスイメージの停止および削除 podman-compose down --rmi all
サービスの強制削除
停止中のコンテナを削除する。
podman-compose rm
サービスの強制消去
サービスを強制停止する。
podman-compose kill
コマンドの実行
引数で指定したサービスのコンテナ内でコマンドを実行する。
podman-compose run <サービス名> <コマンド> <引数 1> <引数 2> <引数...> # 例: container-compose.ymlファイル内のdbを強制的にpullして、dbおよびwebを実行する podman-compose run db web new . --force --database=mysql
サービスの設定の確認
container-compose.ymlファイルで記述されている設定を表示する。
podman-compose config
サービスログの確認
サービスのログを表示する。
podman-compose logs
Kubernetes YAMLへ変換
Container-compose.ymlファイルからポッドを構築する。
podman-compose up -d # または podman-compose up -d -f <Container-compose.ymlファイルのパス>
Kubernetes YAMLファイルへ変換する。
podman generate kube <ポッド名> > <Kubernetes YAMLファイル名>.yml