So habe ich meine Rolle jetzt funktioniert, das Ergebnis ist jetzt in "var" und ich sehe eine Ausgabe. Vor allem ist hier die Rolle, die ich geschrieben habe:Ansible Rückgabewert - Extrahiere eine bestimmte Zeile
- name: create a server
os_server:
state: present
flavor: m1.nano
auth:
auth_url: ****
username: ****
password: ****
project_name: admin
domain_id: ****
name: ansibletest
# region_name: RegionOne
image: 4e7ab5c8-4b39-4c77-b68d-cf2ea7e1df1a
key_name: ansible
timeout: 200
auto_ip: yes
nics:
- net-id: a5a73ab9-3ee5-49a6-bea0-f44f9e376ca0
register: result
- debug: var=result
Und ich bekomme einen langen Ausgang dieser wie diese:
TASK [openstack : debug] *******************************************************
ok: [172.20.22.21] => {
"result": {
"changed": false,
"id": "6f40f396-7ef8-4e0e-9769-2b9cea898269",
.........
"accessIPv4": "172.20.22.58",
.......
{
..........
},
{
............
"addr": "172.20.22.58",
......
}
]
},
........
},
"interface_ip": "172.20.22.58",
.................
.............
]
},
"os-extended-volumes:volumes_attached": [],
"private_v4": "10.0.100.92",
"progress": 0,
"public_v4": "172.20.22.58",
................
{
...........
}
}
Ich brauche nur die IP-Adresse (in diesem Fall ist es die 172.20.22.58
enthalten in "accessIPv4"
) - gibt es eine Möglichkeit, den Ausgang zu "filtern", um diesen Wert einfach abzurufen?
Versuchen Sie result.interface_ip – Nasr