I have a test playbook to mount different types of mounts. It works when I don't use variables for the values, however fails DNS resolution when I do. I'm unsure why this is:
Playbook:
---
- hosts: all
become: true
gather_facts: yes
vars:
shares:
- environments:
- environment: test
mounts:
- dest: '/mnt/cifs/share2'
src: //windows.example.com/share2
opts: 'x-systemd.automount,rw,vers=2.1,sec=krb5i,[email protected],uid=test,gid=test,file_mode=0770,dir_mode=0770,rsize=32768,wsize=32768'
type: 'cifs'
- dest: /mnt/efs/share2
src: fs-0e7af4f4f58ff4dcd.efs.us-east-2.amazonaws.com
type: efs
opts: 'x-systemd.automount,_netdev,tls,accesspoint=fsap-0395b37eaf8cbbf9e'
tasks:
- name: Mount CIFS Share
ansible.posix.mount:
src: fs-0e7af4f4f58ff4dcd.efs.us-east-2.amazonaws.com
path: /mnt/efs/share1
fstype: efs
opts: 'x-systemd.automount,_netdev,tls,accesspoint=fsap-e9fbbc8ae74b5930'
state: mounted
- name: Mount EFS Share
ansible.posix.mount:
src: //windows.example.com/share1
path: /mnt/cifs/share1
fstype: cifs
opts: 'x-systemd.automount,rw,vers=2.1,sec=krb5i,[email protected],uid=test,gid=test,file_mode=0770,dir_mode=0770,rsize=32768,wsize=32768'
state: mounted
- name: Mount Shares
ansible.posix.mount:
src: |-
{%- if item.1.type == "cifs" -%}
\\ "{{item.1.src}}"
{%- else -%}
"{{item.1.src}}"
{%- endif -%}
path: "{{item.1.dest}}"
fstype: "{{item.1.type}}"
opts: "{{item.1.opts}}"
state: mounted
with_subelements:
- "{{ shares | map(attribute='environments') | list | sum(start=[]) }}"
- mounts
when: item.0.environment == 'test'
...
Result
[mose@lab ~/ansible]$ ansible-playbook -Ki hosts test-mounts.yml
BECOME password:
PLAY [all] ***********************************************************************************************************************************************************************************************************************************
TASK [Gathering Facts] ***********************************************************************************************************************************************************************************************************************
ok: [server.example.com]
TASK [Mount CIFS Share] **********************************************************************************************************************************************************************************************************************
ok: [server.example.com]
TASK [Mount EFS Share] ***********************************************************************************************************************************************************************************************************************
ok: [server.example.com]
TASK [Mount Shares] **************************************************************************************************************************************************************************************************************************
failed: [server.example.com] (item=[{'environment': 'test'}, {'dest': '/mnt/cifs/share2', 'src': 'server.example.com/mnt/cifs/share2', 'opts': 'x-systemd.automount,rw,vers=2.1,sec=krb5i,[email protected],uid=test,gid=test,file_mode=0770,dir_mode=0770,rsize=32768,wsize=32768', 'type': 'cifs'}]) => {"ansible_loop_var": "item", "changed": false, "item": [{"environment": "test"}, {"dest": "/mnt/cifs/share2", "opts": "x-systemd.automount,rw,vers=2.1,sec=krb5i,[email protected],uid=test,gid=test,file_mode=0770,dir_mode=0770,rsize=32768,wsize=32768", "src": "server.example.com/mnt/cifs/share2", "type": "cifs"}], "msg": "Error mounting /mnt/cifs/share2: mount error: could not resolve address for \"server.example.com: Unknown error\n"}
failed: [server.example.com] (item=[{'environment': 'test'}, {'dest': '/mnt/efs/share2', 'src': 'fs-0e7af4f4f58ff4dcd.efs.us-east-2.amazonaws.com', 'type': 'efs', 'opts': 'x-systemd.automount,_netdev,tls,accesspoint=fsap-e9fbbc8fae73b5930'}]) => {"ansible_loop_var": "item", "changed": false, "item": [{"environment": "test"}, {"dest": "/mnt/efs/share2", "opts": "x-systemd.automount,_netdev,tls,accesspoint=fsap-e9fbbc8fae73b5930", "src": "fs-0e7af4f4f58ff4dcd.efs.us-east-2.amazonaws.com", "type": "efs"}], "msg": "Error mounting /mnt/efs/share2: Failed to resolve \"\"fs-0e7af4f4f58ff4dcd.efs.us-east-2.amazonaws.com\"\" - check that the specified DNS name is a CNAME record resolving to a valid EFS DNS name\n"}
PLAY RECAP ***********************************************************************************************************************************************************************************************************************************
server.example.com : ok=3 changed=0 unreachable=0 failed=1 skipped=0 rescued=0 ignored=0
Note, content is sanitized; in my actual example the values for each of the NFS/CIFS shares are precisely the same. Both client and server are running the same OS/ansible version:
[mose@lab ~/ansible]$ ansible --version
ansible [core 2.14.14]
config file = /home/mose/ansible/ansible.cfg
configured module search path = ['/home/mose/.ansible/plugins/modules', '/usr/share/ansible/plugins/modules']
ansible python module location = /usr/lib/python3.9/site-packages/ansible
ansible collection location = /home/mose/.ansible/collections:/usr/share/ansible/collections
executable location = /usr/bin/ansible
python version = 3.9.18 (main, Jan 24 2024, 00:00:00) [GCC 11.4.1 20231218 (Red Hat 11.4.1-3)] (/usr/bin/python3)
jinja version = 3.1.2
libyaml = True
[mose@lab ~/ansible]$ cat /etc/redhat-release
Red Hat Enterprise Linux release 9.4 (Plow)
I found the issue, the variable being encapsulated by quotes "
's was the culprit. I changed:
"{{item.1.src}}"
to:
{{item.1.src}}
And mounts started working. Ironically, I recall getting a syntax error stating that former should be used.