16.8. Ansible Playbook を使用して IdM ホストグループを存在させないようにする方法

本セクションでは、Ansible Playbook を使用して、Identity Management (IdM) にホストグループを存在させないようにする方法を説明します。

注記

Ansible を使用しないと、ipa hostgroup-del コマンドを使用して、ホストグループエントリーが IdM から削除されます。IdM からホストグループを削除する結果は、IdM に存在しないホストグループの状態です。Ansible はべき等性に依存しているため、Ansible を使用して IdM からホストグループを削除するには、ホストグループの状態を absent: state: absent として定義する Playbook を作成する必要があります。

前提条件

  • IdM 管理者パスワードが分かっている。
  • Ansible コントローラーに ansible-freeipa パッケージがインストールされている。

手順

  1. inventory.file などのインベントリーファイル を作成し、ターゲットに設定する IdM サーバーの一覧と共に ipaserver を定義します。

    [ipaserver]
    server.idm.example.com
  2. 必要なホストグループ情報を使用して Ansible Playbook ファイルを作成します。この手順を単純化するには、/usr/share/doc/ansible-freeipa/playbooks/user/ensure-hostgroup-is-absent.yml ファイルのサンプルをコピーして変更できます。

    ---
    - name: Playbook to handle hostgroups
      hosts: ipaserver
      become: true
    
      tasks:
      - Ensure host-group databases is absent
        ipahostgroup:
          ipaadmin_password: MySecret123
          name: databases
          state: absent

    この Playbook は、IdM からの データベース ホストグループがないことを確認します。state: absent は、削除しない限り、IdM からホストグループを削除する要求を意味します。

  3. Playbook を実行します。

    $ ansible-playbook -v -i path_to_inventory_directory/inventory.file path_to_playbooks_directory/ensure-hostgroup-is-absent.yml

検証手順

  1. admin として ipaserver にログインします。

    $ ssh admin@server.idm.example.com
    Password:
    [admin@server /]$
  2. admin の Kerberos チケットを要求します。

    $ kinit admin
    Password for admin@IDM.EXAMPLE.COM:
  3. 確実に見つからないホストグループに関する情報を表示します。

    $ ipa hostgroup-show databases
    ipa: ERROR: databases: host group not found

databases ホストグループが IdM に存在しません。