第4章 自動化実行環境の公開
4.1. 既存の自動化実行環境イメージのカスタマイズ
Ansible Controller には、以下のデフォルトの実行環境が含まれます。
-
最小限
- 最新の Ansible-core 2.15 リリースと Ansible Runner が含まれますが、コレクションやその他のコンテンツは含まれません。 -
EE Supported
- Minimal に加え、Red Hat がサポートするすべてのコレクションと依存関係が含まれています。
これらの環境は多くの自動化ユースケースに対応しますが、追加の項目を追加して、特定のニーズに合わせてこれらのコンテナーをカスタマイズできます。以下の手順では、kubernetes.core
コレクションを ee-minimal
デフォルトイメージに追加します。
手順
Podman を使用して
registry.redhat.io
にログインします。$ podman login -u="[username]" -p="[token/hash]" registry.redhat.io
必要な自動化実行環境のベースイメージをプルできることを確認します。
podman pull registry.redhat.io/ansible-automation-platform-24/ee-minimal-rhel8:latest
必要なベースイメージと新しい実行環境イメージに追加する追加のコンテンツを指定するように Ansible Builder ファイルを設定します。
たとえば、Galaxy の Kubernetes Core Collection をイメージに追加するには、Galaxy エントリーを使用します。
collections: - kubernetes.core
- 定義ファイルとその内容の詳細は、定義ファイルの内訳 セクションを参照してください。
実行環境定義ファイルで、
EE_BASE_IMAGE
フィールドに元のee-minimal
コンテナーの URL とタグを指定します。その場合、最終的なexecution-environment.yml
ファイルは以下のようになります。例4.1 カスタマイズされた
execution-environment.yml
ファイルversion: 3 images: base_image: 'registry.redhat.io/ansible-automation-platform-25/ee-minimal-rhel9:latest' dependencies: galaxy: collections: - kubernetes.core
注記この例では、自動化ハブの認定コレクションではなく、コミュニティーバージョンの
kubernetes.core
を使用するため、ansible.cfg
ファイルを作成したり、定義ファイルで参照したりする必要はありません。以下のコマンドを使用して、新しい実行環境イメージをビルドします。
$ ansible-builder build -t [username]/new-ee
ここで、
[username]
はユーザー名を指定し、new-ee
は新しいコンテナーイメージの名前を指定します。注記build
で-t
を使用しない場合は、ansible-execution-env
というイメージが作成され、ローカルのコンテナーレジストリーに読み込まれます。podman images
コマンドを使用して、新しいコンテナーイメージが一覧に表示されていることを確認します。例4.2
new-ee
イメージを使用したpodman images
コマンドの出力REPOSITORY TAG IMAGE ID CREATED SIZE localhost/new-ee latest f5509587efbb 3 minutes ago 769 MB
コレクションがインストールされていることを確認します。
$ podman run [username]/new-ee ansible-doc -l kubernetes.core
Automation Hub で使用するイメージにタグを付けます。
$ podman tag [username]/new-ee [automation-hub-IP-address]/[username]/new-ee
Podman を使用して Automation Hub にログインします。
注記コンテナーをプッシュするには、Automation Hub の
admin
または適切なコンテナーリポジトリーのアクセス許可が必要です。詳細は、Private Automation Hub でのコンテナーの管理 を参照してください。$ podman login -u="[username]" -p="[token/hash]" [automation-hub-IP-address]
イメージを自動化ハブのコンテナーレジストリーにプッシュします。
$ podman push [automation-hub-IP-address]/[username]/new-ee
新しいイメージを自動化コントローラーインスタンスにプルします。
- Automation Controller に移動します。
-
ナビゲーションパネルから、
を選択します。 - をクリックします。
適切な情報を入力して
をクリックし、新規イメージにプルします。注記自動化ハブのインスタンスがパスワードまたはトークンで保護されている場合は、適切なコンテナーレジストリーの認証情報が設定されていることを確認してください。