So isolieren Sie die Ansible-Ausgabe basierend auf dem Schlüssel

So isolieren Sie die Ansible-Ausgabe basierend auf dem Schlüssel

Ich versuche, die Ausgabe des Ansible-Playbooks zu isolieren, aber es heißt"output.stdout": "VARIABLE IS NOT DEFINED!"

Mein Playbook-Code lautet: --- - hosts: localhost tasks: - name: Register variable shell: "echo {{ item }}" loop: - "one" - "two" register: output - debug: var: output.stdout

Interessanterweise funktioniert die Debug-Ausgabe einwandfrei, wenn ich sie nicht mit stdouteinem Schlüssel isoliere.

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,

Was mache ich falsch ?

Antwort1

https://docs.ansible.com/ansible/latest/user_guide/playbooks_loops.html#registering-variables-with-a-loop

Wenn Sie register mit einer Schleife verwenden, enthält die in der Variable platzierte Datenstruktur ein results-Attribut, das eine Liste aller Antworten des Moduls darstellt.

Daher:

output.results[0].stdout
output.results[1].stdout

Antwort2

Eine einfachere Möglichkeit wäre, eine Schleife in eine separate .yml-Datei (über Include) zu erstellen, die eine einfache Operation + Ausgabe durchführt. Beispiel:

main.yml:

- name: RUN start.yml
  include: start.yml
  vars:
    app: "{{ item.name }}"
  static: false
  with_items: "{{ list_items }}"

start.yml in derselben Rolle:

- name: "Run {{ app }}"
  command: './runapp.sh {{ app }}'
  register: start_app_register
  no_log: True

- debug:
    msg: '{{ start_app_register.stdout }}'

verwandte Informationen