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 stdout
einem 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
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 }}'