Eu estou tentando fazer um loop em um dicionário customizado para verificar alguns pontos de montagem em um servidor linux, e estou com um pouco de dificuldade em encontrar a solução correta, encontre abaixo o meu manual agora:
- name: Check lvm devs
hosts: localhost
vars:
vg_os: vg_root
fs_configuration:
- /:
lvm_device: "/dev/mapper/{{ vg_os }}-lv_root"
lvm_size: 8589934592
- /var:
lvm_device: "/dev/mapper/{{ vg_os }}-lv_var"
lvm_size: 6442450944
- /var/crash:
lvm_device: "/dev/mapper/{{ vg_os }}-lv_crash"
lvm_size: 6442450944
- test:
lvm_device: "/dev/mapper/{{ vg_os }}-lv_crash"
lvm_size: 6442450944
tasks:
- name: Debug dict
debug:
msg: "{{ fs_configuration }}"
- name: Check Dev /
assert:
that: "'{{ item.value.lvm_device }}' == '{{ ansible_mounts | json_query('[?mount == '/' ] | [0].device') }}'"
with_dict: "{{ fs_configuration }}"
when: " item.key == '/' "
Eu estava tentando criar um loop personalizado para percorrer as entradas do dicionário e fazer o mesmo tipo de verificação com menos código, algo assim
- name: Check Dev loop
assert:
that: "'{{ item.value.lvm_device }}' == '{{ ansible_mounts | json_query('[?mount == '{{item.key}}' ] | [0].device') }}'"
with_dict: "{{ fs_configuration }}"
Mas eu não sou capaz de expandir a variável dentro de json_query ({{item.key}}).
Eu suponho que há maneira de escapar ou passar a variável, mas não consigo encontrar uma solução.
Eu prefiro fazer um único loop em vez de escrever várias tarefas para verificar todos os sistemas de arquivos
failed: [localhost] (item={'value': {u'lvm_size': 8589934592, u'lvm_device': u'/dev/mapper/vg_root-lv_root'}, 'key': u'/'}) => {
**"assertion": "'/dev/mapper/vg_root-lv_root' == ''",** <-- not working
"changed": false,
"evaluated_to": false,
"item": {
"key": "/",
"value": {
"lvm_device": "/dev/mapper/vg_root-lv_root",
"lvm_size": 8589934592
}
}
}
Obrigado!