我有以下戏剧:
- 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"