Linuxサーバー上のいくつかのマウントポイントを確認するために、ansibleのカスタム辞書でループしようとしています。正しい解決策を見つけるのに少し苦労しています。今すぐプレイブックを見つけてください:
- 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 == '/' "
辞書エントリを循環するカスタムループを作成して、同じようなチェックを少ないコードで実行しようとしていました。
- name: Check Dev loop
assert:
that: "'{{ item.value.lvm_device }}' == '{{ ansible_mounts | json_query('[?mount == `{{item.key}}` ] | [0].device') }}'"
with_dict: "{{ fs_configuration }}"
しかし、json_query({{item.key}})内の変数を展開することはできません。変数をエスケープまたは渡す方法はあると思いますが、解決策が見つかりません。すべてのファイルシステムをチェックするために複数のタスクを書くのではなく、単一のループを作ることを好みます
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
}
}
}
ありがとう!
タスク変数を使用できます。
- name: Check Dev loop
assert:
that: "'{{ item.value.lvm_device }}' == '{{ ansible_mounts | json_query(query) }}'"
with_dict: "{{ fs_configuration }}"
vars:
query: '[?mount == `{{ item.key }}` ] | [0].device'