37.10. Ansible を使用して、特定のホスト上の IdM ユーザーのログイン名とホームディレクトリーをオーバーライドする


ansible-freeipa の idoverrideuser モジュールを使用すると、特定のホスト上で、ログイン名やホームディレクトリーなどの Identity Management (IdM) ユーザーの POSIX 属性を上書きして、ホスト固有のカスタム設定を行うことができます。

この手順では、idm_user という名前の IdM ユーザーがログイン名 user_1234 を使用して client1.idm.example.com という名前の IdM クライアントにログインできるようにする ID ビューの例を使用します。さらに、この ID ビューは idm_user のホームディレクトリーを変更します。そのため、client1 へのログイン後、ユーザーのホームディレクトリーが /home/user_1234/ になります。

前提条件

  • コントロールノード:

    • Ansible バージョン 2.15 以降を使用している。
    • ansible-freeipa パッケージがインストールされている。
    • ~/MyPlaybooks/ ディレクトリーに、IdM サーバーの完全修飾ドメイン名 (FQDN) を使用して Ansible インベントリーファイル が作成されている (この例の場合)。
    • secret.yml Ansible vault に ipaadmin_password が保存されており、secret.yml ファイルを保護するパスワードを格納しているファイルにアクセスできる (この例の場合)。
  • ターゲットノード (freeipa.ansible_freeipa モジュールが実行されるノード) が、IdM クライアント、サーバー、またはレプリカとして IdM ドメインに含まれている。

手順

  1. 次の内容を含む Ansible Playbook ファイル add-idoverrideuser-with-name-and-homedir.yml を作成します。

    ---
    - name: Playbook to manage idoverrideuser
      hosts: ipaserver
      become: false
      gather_facts: false
      vars_files:
      - /home/user_name/MyPlaybooks/secret.yml
    
      tasks:
      - name: Ensure idview_for_client1 is present
        idview:
          ipaadmin_password: "{{ ipaadmin_password }}"
          name: idview_for_client1
      - name: Ensure idview_for_client1 is applied to client1.idm.example.com
        idview:
          ipaadmin_password: "{{ ipaadmin_password }}"
          name: idview_for_client1
          host: client1.idm.example.com
          action: member
      - name: Ensure idm_user is present in idview_for_client1 with homedir /home/user_1234 and name user_1234
        ipaidoverrideuser:
          ipaadmin_password: "{{ ipaadmin_password }}"
          idview: idview_for_client1
          anchor: idm_user
          name: user_1234
          homedir: /home/user_1234
  2. Playbook を実行します。Playbook ファイル、secret.yml ファイルを保護するパスワードを格納するファイル、およびインベントリーファイルを指定します。

    $ ansible-playbook --vault-password-file=password_file -v -i <path_to_inventory_directory>/inventory <path_to_playbooks_directory>/add-idoverrideuser-with-name-and-homedir.yml
  3. オプション: root の認証情報を持っている場合は、新しい設定を IdM クライアントシステムにすぐに適用できます。

    1. クライアントシステムに root として SSH 接続します。

      $ ssh root@client1
      Password:
    2. IdM クライアントで、SSSD キャッシュをクリアします。

      # sss_cache -E
    3. IdM クライアントで、SSSD デーモンを再起動します。

      # systemctl restart sssd

検証

  1. idm_user として IdM クライアントに SSH 接続します。

    # ssh idm_user@client1.idm.example.com
    Password:
    
    Last login: Sun Jun 21 22:34:25 2020 from 192.168.122.229
    [user_1234@client1 ~]$
  2. 作業ディレクトリーを出力します。

    $ pwd
    /home/user_1234/
Red Hat logoGithubredditYoutubeTwitter

詳細情報

試用、購入および販売

コミュニティー

会社概要

Red Hat は、企業がコアとなるデータセンターからネットワークエッジに至るまで、各種プラットフォームや環境全体で作業を簡素化できるように、強化されたソリューションを提供しています。

多様性を受け入れるオープンソースの強化

Red Hat では、コード、ドキュメント、Web プロパティーにおける配慮に欠ける用語の置き換えに取り組んでいます。このような変更は、段階的に実施される予定です。詳細情報: Red Hat ブログ.

Red Hat ドキュメントについて

Legal Notice

Theme

© 2026 Red Hat
トップに戻る