28.3. Ansible을 사용하여 IdM에 DNS 글로벌 전달자가 있는지 확인
Ansible 플레이북을 사용하여 IdM에 DNS 글로벌 전달자가 없는지 확인하려면 다음 절차를 따르십시오. 아래 예제 절차에서는 IdM 관리자가 인터넷 프로토콜(IP) v4 주소가 8.8.6.6 이고 IP v6 주소가 2001:4860:4860::8800 인 DNS 글로벌 전달자가 없는지 확인합니다.
사전 요구 사항
다음 요구 사항을 충족하도록 Ansible 제어 노드를 구성했습니다.
- Ansible 버전 2.15 이상을 사용하고 있습니다.
-
freeipa.ansible_freeipa컬렉션을 설치했습니다. - 이 예제에서는 ~/MyPlaybooks/ 디렉터리에서 IdM 서버의 FQDN(정규화된 도메인 이름)을 사용하여 Ansible 인벤토리 파일을 생성했다고 가정합니다.
-
이 예제에서는 secret.yml Ansible vault가
ipaadmin_password를 저장하고 secret.yml 파일을 보호하는 암호를 저장하는 파일에 대한 액세스 권한이 있다고 가정합니다.
-
freeipa.ansible_freeipa모듈이 실행되는 대상 노드인 대상 노드는 IdM 도메인의 일부입니다. IdM 클라이언트, 서버 또는 복제본입니다.
프로세스
~/MyPlaybooks/ 디렉터리로 이동합니다.
$ cd ~/MyPlaybooks/관련 collections 디렉터리에서 forwarders-absent.yml Ansible 플레이북 파일의 사본을 만들고 이름을 바꿉니다. 예를 들면 다음과 같습니다.
$ cp /usr/share/ansible/collections/ansible_collections/freeipa/ansible_freeipa/playbooks/dnsconfig/forwarders-absent.yml ensure-absence-of-a-global-forwarder.yml-
편집을
위해 ensure-absence-of-global-forwarder.yml파일을 엽니다. 다음 변수를 설정하여 파일을 조정합니다.
-
IdM DNS에 글로벌 전달자가 없는지 확인하기 위해 플레이북의변경합니다.name변수를 Playbook로 -
tasks섹션에서 DNS 글로벌 전달자가 없는지 확인하려면 포트 53의 DNS 글로벌 전달자가 8.8.6.6 및 2001:4860:4860::8800으로 변경되도록작업이름을변경합니다. freeipa.ansible_freeipa.ipadnsconfig부분의전달자섹션에서 다음을 수행합니다.-
첫 번째
ip_address값을 글로벌 전달자의 IPv4 주소로 변경합니다.8.8.6.6. -
두 번째
ip_address값을 글로벌 전달자2001:4860:4860::8800의 IPv6 주소로 변경합니다. -
port값이53으로 설정되어 있는지 확인합니다.
-
첫 번째
-
action변수를member로 설정합니다. -
상태가absent로 설정되어 있는지 확인합니다.
현재 예에 대해 수정된 Ansible 플레이북 파일입니다.
--- - name: Playbook to ensure the absence of a global forwarder in IdM DNS hosts: ipaserver vars_files: - /home/user_name/MyPlaybooks/secret.yml tasks: - name: Ensure the absence of a DNS global forwarder to 8.8.6.6 and 2001:4860:4860::8800 on port 53 freeipa.ansible_freeipa.ipadnsconfig: forwarders: - ip_address: 8.8.6.6 - ip_address: 2001:4860:4860::8800 port: 53 action: member state: absent중요action: member를 사용하지 않고 플레이북에서state: absent옵션만 사용하면 플레이북이 실패합니다.-
- 파일을 저장합니다.
Playbook을 실행합니다.
$ ansible-playbook --vault-password-file=password_file -v -i inventory.file ensure-absence-of-a-global-forwarder.yml