Estou tentando isolar a saída do manual ansible, no entanto, ele diz"output.stdout": "VARIABLE IS NOT DEFINED!"
O código do meu manual é:
--- - hosts: localhost tasks: - name: Register variable shell: "echo {{ item }}" loop: - "one" - "two" register: output - debug: var: output.stdout
Curiosamente, a saída de depuração funciona bem se eu não isolá-la usando stdout
a chave.
TASK [Register variable] ***********************************************************************************************************************************************
changed: [localhost] => (item=one)
changed: [localhost] => (item=two)
TASK [debug] ***********************************************************************************************************************************************************
ok: [localhost] => {
"output": {
"changed": true,
"msg": "All items completed",
"results": [
{
"ansible_loop_var": "item",
"changed": true,
"cmd": "echo one",
"delta": "0:00:00.002986",
"end": "2020-01-24 00:20:57.226744",
"failed": false,
"invocation": {
"module_args": {
"_raw_params": "echo one",
"_uses_shell": true,
"argv": null,
"chdir": null,
"creates": null,
O que estou fazendo de errado ?
Responder1
Quando você usa o registro com um loop, a estrutura de dados colocada na variável conterá um atributo de resultados que é uma lista de todas as respostas do módulo
Por isso:
output.results[0].stdout
output.results[1].stdout
Responder2
Uma maneira mais fácil seria fazer um loop em um arquivo .yml separado (via include), que executará uma operação suave + saída. Por exemplo:
principal.yml:
- name: RUN start.yml
include: start.yml
vars:
app: "{{ item.name }}"
static: false
with_items: "{{ list_items }}"
start.yml na mesma função:
- name: "Run {{ app }}"
command: './runapp.sh {{ app }}'
register: start_app_register
no_log: True
- debug:
msg: '{{ start_app_register.stdout }}'