Ansible:変数を繰り返し、変数が定義されている場合はコマンドを実行します。

Ansible:変数を繰り返し、変数が定義されている場合はコマンドを実行します。

ansibleを使用して/etc/resolv.confにネームサーバーを設定したいと思います。基本的に変数(DNS1、DNS2、DNS3)を設定したいと思います。定義されている場合にのみDNS#を適用したいと思います。これまでのところ、私は以下を持っています。

# Run this playbook on all hosts that should query the DNS server.
- hosts: all
  vars:
    # dns_server: 192.168.1.190
    nameserver_ip: 192.168.1.214
    DNS2: 192.168.1.1
  tasks:
    - name: Add DNS server's IPv4 address to /etc/resolv.conf
      command: "nmcli con mod {{ ansible_default_ipv4['interface'] }} ipv4.dns {{ nameserver_ip }}"
    - name: Add non-authoritative DNS servers to /etc/resolv.conf
      shell: "nmcli con mod {{ ansible_default_ipv4['interface'] }} +ipv4.dns {{ item }}"
      when:  item is defined
      with_items:
        - DNS2
        - DNS3
    - name: Restart default network interface to update /etc/resolv.conf
      shell: "nmcli con reload && nmcli con up {{ ansible_default_ipv4['interface'] }}"

しかし、これを実行すると、次のエラーが発生します。

[root@ns1 dns]# ansible-playbook --user root -i ftp.home, dns_client.yaml -k
...
...
TASK [Add non-authoritative DNS servers to /etc/resolv.conf] *****************************************************************************************************************************************************
failed: [ftp.home] (item=DNS2) => {"changed": true, "cmd": "nmcli con mod eth0 +ipv4.dns DNS2", "delta": "0:00:00.055982", "end": "2019-04-01 12:25:53.029983", "item": "DNS2", "msg": "non-zero return code", "rc": 2, "start": "2019-04-01 12:25:52.974001", "stderr": "Error: failed to modify ipv4.dns: invalid IPv4 address 'DNS2'.", "stderr_lines": ["Error: failed to modify ipv4.dns: invalid IPv4 address 'DNS2'."], "stdout": "", "stdout_lines": []}
failed: [ftp.home] (item=DNS3) => {"changed": true, "cmd": "nmcli con mod eth0 +ipv4.dns DNS3", "delta": "0:00:00.056684", "end": "2019-04-01 12:25:53.782999", "item": "DNS3", "msg": "non-zero return code", "rc": 2, "start": "2019-04-01 12:25:53.726315", "stderr": "Error: failed to modify ipv4.dns: invalid IPv4 address 'DNS3'.", "stderr_lines": ["Error: failed to modify ipv4.dns: invalid IPv4 address 'DNS3'."], "stdout": "", "stdout_lines": []}
        to retry, use: --limit @/root/ansible/dns/dns_client.retry

DNS{2,3} 値を使用するのではなく、文字通り DNS2 および DNS3 変数名を使用するようです。私がここで何を間違っているのか?

答え1

私はそれについて考えた。 Ansibleで変数の値を使用するには、変数名を「{{...}}」で囲む必要があることを忘れました。次の変更で問題が解決しました。

  with_items:
    - "{{ DNS2 }}"
    - "{{ DNS3 }}"

関連情報