![Ansible with_items não está em loop](https://rvso.com/image/776319/Ansible%20with_items%20n%C3%A3o%20est%C3%A1%20em%20loop.png)
Acho que já estou nisso há muito tempo, mas não consigo entender por que meu segundocom_itensnão está em loop como o meu primeiro. Eu já tentei usar umjson_querycomo na primeira tarefa, que não ajudou.
Tarefa:
- name: Set backing_lunuuid
set_fact:
backing_lunuuid: "{{ item | json_query('guest_disk_info.*.backing_lunuuid') }}"
with_items: " {{ rdm_jsondata.results }}"
- debug:
msg: " {{ backing_lunuuid }}"
- name: Remove leading and trailing backing_lunuuid to set disk.UUID
set_fact:
rdm_uuid: "{{ item[10:-12] }}"
with_items: " {{ backing_lunuuid }}"
- debug:
msg: " {{ rdm_uuid }}"
Primeira saída de depuração (para backing_lunuuid):
TASK [debug] ********************************************************************************************************************************************************************************************
ok: [localhost] => {
"msg": " ['0200110000600507681081007e1800000000000053323134352020', '02000f0000600507681081007e1800000000000051323134352020', '0200150000600507681081007e1800000000000059323134352020', '0200130000600507681081007e1800000000000055323134352020', '0200140000600507681081007e1800000000000056323134352020', '0200240000600507681081007e1800000000000057323134352020', '0200420000600507681081007e1800000000000058323134352020', '0200100000600507681081007e1800000000000052323134352020', '0200120000600507681081007e1800000000000054323134352020']"
Segunda saída de depuração (para rdm_uuid), que não está em loop como a primeira"
TASK [Remove leading and trailing backing_lunuuid to set disk.UUID] *************************************************************************************************************************************
ok: [localhost] => (item=0200110000600507681081007e1800000000000053323134352020)
ok: [localhost] => (item=02000f0000600507681081007e1800000000000051323134352020)
ok: [localhost] => (item=0200150000600507681081007e1800000000000059323134352020)
ok: [localhost] => (item=0200130000600507681081007e1800000000000055323134352020)
ok: [localhost] => (item=0200140000600507681081007e1800000000000056323134352020)
ok: [localhost] => (item=0200240000600507681081007e1800000000000057323134352020)
ok: [localhost] => (item=0200420000600507681081007e1800000000000058323134352020)
ok: [localhost] => (item=0200100000600507681081007e1800000000000052323134352020)
ok: [localhost] => (item=0200120000600507681081007e1800000000000054323134352020)
TASK [debug] ********************************************************************************************************************************************************************************************
ok: [localhost] => {
"msg": " 600507681081007e1800000000000054"
Qualquer ajuda seria muito apreciada.
Responder1
Você está sobrescrevendo rdm_uuid
cada iteração do loop. Tente algo assim:
- name: Remove leading and trailing backing_lunuuid to set disk.UUID
set_fact:
rdm_uuid: "{{ rdm_uuid | default([]) + [item[10:-12]] }}"
with_items: " {{ backing_lunuuid }}"
Editar: o primeiro está fazendo a mesma coisa, mas o último elemento rdm_jsondata.results
contém os dados que você precisa. Tente olhar rdm_jsondata.results
.
Responder2
Usarregex_replacecortar os itens em um tubo
rdm_uuid: "{{ backing_lunuuid|map('regex_replace', regex, replace)|list }}"
regex: '.{10}(.*).{12}'
replace: '\1'