团队
我有一个文本文件,其中包含需要使用uri anisible模块启动的url,并捕获其结果以检查http_status代码是否为200。我的剧本在下面,但出现错误:
当我使用vars文件中的已定义变量时,其工作相同。但是当我从GREP结果的输出中使用它时,它不起作用。如果我切换我的评论,它将起作用。那就是我使用
url: https://'{{ site_from_vars_file }}'
-
name: Test connectivity to target servers
hosts: all
vars_files:
- vars.yaml
- name: "GREP API server name.. "
shell: "grep 443 $HOME/.kube/config/cluster-user.kubeconfig | awk -F '//' '{print $2}'"
register: grep_output
ignore_errors: true
- debug:
var: grep_output.stdout_lines
when: grep_output.stdout != ''
- name: "Validate site reachability response as 200 okay "
uri:
#url: https://'{{ site_from_vars_file }}'
url: https://'{{ grep_output }}'
return_content: yes
validate_certs: no
register: uri_output
failed_when: uri_output.status not in [200]
输出:
TASK [Gathering Facts] ****************************************************************************************************************************************
ok: [target1]
TASK [DNS test] ***********************************************************************************************************************************************
changed: [target1]
TASK [Validate DNS server] ************************************************************************************************************************************
ok: [target1] => {
"msg": "Resolved DNS server 'site.test.com' '69.172.200.109' "
}
TASK [GREP API server name..] *********************************************************************************************************************************
changed: [target1]
TASK [debug] **************************************************************************************************************************************************
ok: [target1] => {
"grep_output.stdout_lines": [
"site.test.com:443"
]
}
TASK [Validate site reachability response as 200 okay] ***************************************************************************************
fatal: [target1]: FAILED! => {"changed": false, "failed_when_result": true, "msg": "invalid literal for int() with base 10: \"True, 'end'\"", "status": -1, "url": "https://'{'changed': True, 'end': '2019-09-27 16:52:08.250231', 'stdout': 'site.test.com:443', 'cmd': \"grep 443 $HOME/.kube/config/cluster-user.kubeconfig | awk -F '//' '{print $2}'\", 'rc': 0, 'start': '2019-09-27 16:52:08.241668', 'stderr': '', 'delta': '0:00:00.008563', 'stdout_lines': ['site.test.com:443'], 'stderr_lines': [], 'failed': False}'"}
PLAY RECAP ****************************************************************************************************************************************************
target1 : ok=5 changed=2 unreachable=0 failed=1 skipped=0 rescued=0 ignored=0
答案 0 :(得分:2)
似乎这是问题所在:
url: https://'{{ grep_output }}'
您需要将其更改为以下内容:
url: https://'{{ grep_output.stdout }}'
url: https://'{{ grep_output.stdout_lines }}'
您的游戏现在看起来像这样:
- name: "Validate site reachability response as 200 okay "
uri:
#url: https://'{{ site_from_vars_file }}'
url: https://'{{ grep_output.stdout }}'
return_content: yes
validate_certs: no
register: uri_output
failed_when: uri_output.status not in [200]