簡體   English   中英

Ansible:將命令的標准輸出存儲在新變量中?

[英]Ansible: Store command's stdout in new variable?

在我的劇本中,我想創建一個變量來保存外部命令的輸出。 之后我想在幾個模板中使用該變量。

以下是劇本的相關部分:

  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

假設這是我的模板:

[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

(注意{{ string_to_echo }}

所以我基本上要尋找的是一種將command_output.stdout (在第一個任務期間生成/檢索)的內容存儲在新變量string_to_echo
之后我想在多個模板中使用該變量。

我想我可以在我的模板中使用{{command_output.stdout}} ,但我想擺脫那個.stdout以提高可讀性。

您必須將內容存儲為事實

- set_fact:
    string_to_echo: "{{ command_output.stdout }}"

沒有必要設定一個事實。

    - shell: cat "hello"
      register: cat_contents

    - shell: echo "I cat hello"
      when: cat_contents.stdout == "hello"

在@udondan 的回答之外稍作修改。 我喜歡使用set_fact重用已注冊的變量名稱,以幫助將混亂降至最低。

因此,如果我要使用變量psk進行注冊,我會在創建set_fact使用相同的變量名稱。

示例

- name: generate PSK
  shell: openssl rand -base64 48
  register: psk
  delegate_to: 127.0.0.1
  run_once: true

- set_fact: 
    psk={{ psk.stdout }}

- debug: var=psk
  run_once: true

然后當我運行它時:

$ ansible-playbook -i inventory setup_ipsec.yml

 PLAY                                                                                                                                                                                [all] *************************************************************************************************************************************************************************

 TASK [Gathering                                                                                                                                                                     Facts] *************************************************************************************************************************************************************
 ok: [hostc.mydom.com]
 ok: [hostb.mydom.com]
 ok: [hosta.mydom.com]

 TASK [libreswan : generate                                                                                                                                                          PSK] ****************************************************************************************************************************************************
 changed: [hosta.mydom.com -> 127.0.0.1]

 TASK [libreswan :                                                                                                                                                                   set_fact] ********************************************************************************************************************************************************
 ok: [hosta.mydom.com]
 ok: [hostb.mydom.com]
 ok: [hostc.mydom.com]

 TASK [libreswan :                                                                                                                                                                   debug] ***********************************************************************************************************************************************************
 ok: [hosta.mydom.com] => {
     "psk": "6Tx/4CPBa1xmQ9A6yKi7ifONgoYAXfbo50WXPc1kGcird7u/pVso/vQtz+WdBIvo"
 }

 PLAY                                                                                                                                                                                RECAP *************************************************************************************************************************************************************************
 hosta.mydom.com    : ok=4    changed=1    unreachable=0    failed=0
 hostb.mydom.com    : ok=2    changed=0    unreachable=0    failed=0
 hostc.mydom.com    : ok=2    changed=0    unreachable=0    failed=0

我是 Ansible 的新手,但我建議下一個解決方案:

劇本.yml

...
vars:
  command_output_full:
    stdout: will be overriden below
  command_output: {{ command_output_full.stdout }}
...
...
...
tasks:
  - name: Create variable from command
    command: "echo Hello"
    register: command_output_full
  - debug: msg="{{ command_output }}"

它應該有效(並且對我有用),因為 Ansible 使用惰性求值。 但它似乎在啟動前檢查有效性,所以我必須在 vars 中定義command_output_full.stdout

而且,當然,如果vars部分中有太多這樣的 var,它會看起來很丑陋。

如果您想存儲一個復雜的命令來比較文本結果,例如比較操作系統的版本,也許這可以幫助您:

tasks:
       - shell: echo $(cat /etc/issue | awk {'print $7'})
         register: echo_content

       - shell: echo "It works"
         when: echo_content.stdout == "12"
         register: out
       - debug: var=out.stdout_lines

如果您想更進一步並從 Playbook 結果中提取您想要的確切信息,請使用像 jmespath 這樣的 JSON 查詢語言,例如:

  - name: Sample Playbook
    // Fill up your task
    no_log: True
    register: example_output

  - name: Json Query
    set_fact:
      query_result:
        example_output:"{{ example_output | json_query('results[*].name') }}"

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM