30.12. Ansible を使用して IdM で DNS 正引きゾーンを複数配置する手順
以下の手順に従って、Ansible Playbook を使用して、IdM の DNS 正引きゾーンに複数のフォワーダーがあることを確認します。以下の手順の例では、IdM 管理者が example.com の DNS 正引きゾーンが 8.8.8.8 と 4.4.4.4 に転送されるようにします。
前提条件
次の要件を満たすように Ansible コントロールノードを設定した。
- Ansible バージョン 2.14 以降を使用している。
-
ansible-freeipaパッケージがインストールされている。 - ~/MyPlaybooks/ ディレクトリーに、IdM サーバーの完全修飾ドメイン名 (FQDN) を使用して Ansible インベントリーファイル を作成している (この例の場合)。
-
この例では、secret.yml Ansible Vault に
ipaadmin_passwordが保存されていることを前提としています。
-
ターゲットノード (
ansible-freeipaモジュールが実行されるノード) が、IdM クライアント、サーバー、またはレプリカとして IdM ドメインに含まれている。 - IdM 管理者パスワードを把握している。
手順
/usr/share/doc/ansible-freeipa/playbooks/dnsconfigディレクトリーに移動します。cd /usr/share/doc/ansible-freeipa/playbooks/dnsconfig
$ cd /usr/share/doc/ansible-freeipa/playbooks/dnsconfigCopy to Clipboard Copied! Toggle word wrap Toggle overflow インベントリーファイルを開き、設定する IdM サーバーが
[ipaserver]セクションに記載されていることを確認します。たとえば、Ansible に対してserver.idm.example.comを設定するように指示するには、次のコマンドを実行します。[ipaserver] server.idm.example.com
[ipaserver] server.idm.example.comCopy to Clipboard Copied! Toggle word wrap Toggle overflow Ansible Playbook ファイル (
forwarders-absent.yml) のコピーを作成します。以下に例を示します。cp forwarders-absent.yml ensure-presence-multiple-forwarders.yml
$ cp forwarders-absent.yml ensure-presence-multiple-forwarders.ymlCopy to Clipboard Copied! Toggle word wrap Toggle overflow -
ensure-presence-multiple-forwarders.ymlファイルを開いて編集します。 以下の変数を設定してファイルを調整します。
-
Playbook の
name変数は、IdM DNS の DNS 正引きゾーンに複数のフォワーダーを配置する Playbookの設定に変更します。 -
tasksセクションで、タスクのnameをEnsure presence of 8.8.8.8 and 4.4.4.4 forwarders in dnsforwardzone for example.comに変更します。 -
tasksセクションで、ipadnsconfigのヘディングをipadnsforwardzoneに変更します。 ipadnsforwardzoneセクションで以下を実行します。-
ipaadmin_password変数を追加して、IdM 管理者パスワードに設定します。 -
name変数を追加してexample.comに設定します。 forwardersセクションで、以下を実行します。-
ip_addressとportの行を削除します。 配置する DNS サーバーの IP アドレスを、前にダッシュをつけて追加します。
- 8.8.8.8 - 4.4.4.4
- 8.8.8.8 - 4.4.4.4Copy to Clipboard Copied! Toggle word wrap Toggle overflow
-
- state 変数を present に変更します。
今回の例で使用するように変更した Ansible Playbook ファイル:
-
Copy to Clipboard Copied! Toggle word wrap Toggle overflow -
Playbook の
- ファイルを保存します。
Playbook を実行します。
ansible-playbook --vault-password-file=password_file -v -i inventory.file ensure-presence-multiple-forwarders.yml
$ ansible-playbook --vault-password-file=password_file -v -i inventory.file ensure-presence-multiple-forwarders.ymlCopy to Clipboard Copied! Toggle word wrap Toggle overflow