1

我有以下戏剧:

  - name: packagexx version check
    shell: apk version packagexx | awk 'NR>1{$1=$1;print}'
    when: "'web' in group_names"
    register: packxx_apk_version
    changed_when: False  
  - debug: msg="package_version_check {{inventory_hostname}} {{packxx_apk_version.stdout}}"
    when: "'web' in group_names"
  - name: packagexx individual files check
    shell: apk audit /etc/packagexx/ | grep "^U" | grep -v "kamcc"
    when : "'web' in group_names and '=' in packxx_apk_version.stdout"
    register: ind_file_apk_version
    failed_when: False  
    changed_when: False
  - debug: msg="individual_files_check {{inventory_hostname}} packagexx {{ind_file_apk_version.stdout}}"
    when: "'web' in group_names"

仅当第一次播放的输出包含“=”符号时,才应该运行第二次播放。但是现在,它会在输出如下所示时运行:

  test-web:~# apk version packagexx
  Installed:                                Available:
  packagexx-1.2.0-r3                        < 1.2.1-r1 

最终,当剧本运行时,我最终遇到了这个错误:

TASK [debug] *******************************************************************
fatal: [test-web]: FAILED! => {"failed": true, "msg": "'dict object' has no attribute 'stdout'"}
fatal: [test2-web]: FAILED! => {"failed": true, "msg": "'dict object' has no attribute 'stdout'"}

这是有道理的,因为在包过期的情况下,第二次播放中的命令不应该返回任何内容。

我看不到我的错误在哪里。有什么建议么?

编辑 1

所以在更多的测试中,这就是我发现的。当我在具有最新包的服务器上运行此剧本时(也就是输出中有“=”),它运行得很好。当我在包已过时(输出中没有“=”)的盒子上运行它时,它会返回错误。

错误/缺失部分是最后一个调试语句的条件。它也需要检查“=”。至少这就是我所做的,而且它似乎有效。

所以这:

  - debug: msg="individual_files_check {{inventory_hostname}} packagexx {{ind_file_apk_version.stdout}}"
    when: "'web' in group_names"

改为:

  - debug: msg="individual_files_check {{inventory_hostname}} packagexx {{ind_file_apk_version.stdout}}"
    when: "'web' in group_names and '=' in packxx_apk_version.stdout"
4

1 回答 1

0

我需要在调试语句中添加一个条件,以便仅在输出存在时打印,如下所示:

- debug: msg="individual_files_check {{inventory_hostname}} packagexx {{ind_file_apk_version.stdout}}"
    when: "'web' in group_names and '=' in packxx_apk_version.stdout"
于 2016-04-12T15:28:33.420 回答