私はAnsibleプレイブックの出力を分離しようとしていますが、"output.stdout": "VARIABLE IS NOT DEFINED!"
私のプレイブックのコードは次のとおりです:
--- - hosts: localhost tasks: - name: Register variable shell: "echo {{ item }}" loop: - "one" - "two" register: output - debug: var: output.stdout
興味深いことに、キーを使用して分離しない場合、デバッグ出力は正常に機能しますstdout
。
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,
何が間違っているのでしょうか?
答え1
https://docs.ansible.com/ansible/latest/user_guide/playbooks_loops.html#ループによる変数の登録
ループでレジスタを使用すると、変数に配置されたデータ構造には、モジュールからのすべての応答のリストである結果属性が含まれます。
したがって:
output.results[0].stdout
output.results[1].stdout
答え2
もっと簡単な方法は、別の .yml ファイルにループして (include 経由で)、穏やかな操作 + 出力を実行することです。例:
メイン.yml:
- name: RUN start.yml
include: start.yml
vars:
app: "{{ item.name }}"
static: false
with_items: "{{ list_items }}"
同じロールの start.yml:
- name: "Run {{ app }}"
command: './runapp.sh {{ app }}'
register: start_app_register
no_log: True
- debug:
msg: '{{ start_app_register.stdout }}'