W moim playbooku chciałbym utworzyć zmienną przechowującą dane wyjściowe polecenia zewnętrznego. Następnie chcę użyć tej zmiennej w kilku szablonach.
Oto odpowiednie części poradnika:
tasks:
- name: Create variable from command
command: "echo Hello"
register: command_output
- debug: msg="{{command_output.stdout}}"
- name: Copy test service
template: src=../templates/test.service.j2 dest=/tmp/test.service
- name: Enable test service
shell: systemctl enable /tmp/test.service
- name: Start test service
shell: systemctl start test.service
i powiedzmy, że to mój szablon:
[Unit]
Description=MyApp
After=docker.service
Requires=docker.service
[Service]
TimeoutStartSec=0
ExecStartPre=-/usr/bin/docker kill busybox1
ExecStartPre=-/usr/bin/docker rm busybox1
ExecStartPre=/usr/bin/docker pull busybox
ExecStart=/usr/bin/docker run --name busybox1 busybox /bin/sh -c "while true; do echo {{ string_to_echo }}; sleep 1; done"
[Install]
WantedBy=multi-user.target
(Zwróć uwagę na {{ string_to_echo }}
)
Więc to, czego zasadniczo szukam, to sposób na przechowywanie zawartości command_output.stdout
(która jest generowana / pobierana podczas pierwszego zadania) w nowej zmiennej string_to_echo
.
Ta zmienna, którą chciałbym później użyć w wielu szablonach.
Myślę, że mógłbym po prostu użyć {{command_output.stdout}}
w moich szablonach, ale chcę się tego pozbyć, aby zwiększyć .stdout
czytelność.
ansible
ansible-playbook
Forivin
źródło
źródło
.stdout
.Niewielka modyfikacja poza odpowiedzią @ udondan. Lubię ponownie używać zarejestrowanych nazw zmiennych z rozszerzeniem,
set_fact
aby ograniczyć bałagan do minimum.Więc gdybym miał zarejestrować się przy użyciu zmiennej,
psk
użyłbym tej samej nazwy zmiennej przy tworzeniu plikuset_fact
.Przykład
Następnie, kiedy go uruchomię:
źródło
Jestem nowicjuszem w Ansible, ale proponuję następne rozwiązanie:
playbook.yml
Powinno działać (i działa dla mnie), ponieważ Ansible używa leniwej oceny. Ale wygląda na to, że sprawdza ważność przed uruchomieniem, więc muszę zdefiniować
command_output_full.stdout
w vars.I oczywiście, jeśli w
vars
przekroju jest za dużo takich zmiennych , to będzie wyglądać brzydko.źródło
W przypadku, gdy chcesz zapisać złożone polecenie do porównania wyników tekstowych, na przykład w celu porównania wersji systemu operacyjnego, może to ci pomóc:
źródło
Jeśli chcesz pójść dalej i wyodrębnić dokładne informacje z wyników Playbook, użyj języka zapytań JSON, takiego jak jmespath, przykład:
źródło