在Ansible playbook中使用Command会抛出“无法通过ssh连接到主机”

时间:2017-01-24 01:13:26

标签: ssh ansible

我的剧本中有三个任务。对于所有这些,Ansible需要连接到清单文件中指定的主机。前两个任务执行得很好。第三项任务是

<10.182.1.23> ESTABLISH SSH CONNECTION FOR USER: root
<10.182.1.23> SSH: EXEC sshpass -d12 ssh -C -q -o ControlMaster=auto -o ControlPersist=60s -o StrictHostKeyChecking=no -o User=root -o ConnectTimeout=10 -o ControlPath=/root/.ansible/cp/ansible-ssh-%h-%p-%r 10.182.1.23 '/bin/sh -c '"'"'( umask 77 && mkdir -p "` echo $HOME/.ansible/tmp/ansible-tmp-1485219301.67-103341754305609 `" && echo ansible-tmp-1485219301.67-103341754305609="` echo $HOME/.ansible/tmp/ansible-tmp-1485219301.67-103341754305609 `" ) && sleep 0'"'"''
fatal: [10.182.1.23]: UNREACHABLE! => {"changed": false, "msg": "Failed to connect to the host via ssh.", "unreachable": true}

这是我的剧本 This is a screenshot of my playbook

这是playbook.yml

---
- hosts: all
  strategy: debug
  gather_facts: no
  vars:
    contents: "{{ lookup('file','/etc/redhat-release')}}"
    mydate: "{{lookup('pipe','date +%Y%m%d%H%M%S**.%5N**')}}"
  tasks:
    - name: cat file content
      debug: msg='the content of file is {{contents}} at date {{mydate}}.'
    - name: second task
      debug: msg='this is second task at time {{mydate}}.'
    - name: fourth task
      command: sudo cat /etc/redhat-release
      register: result
    - debug: var=result

这是我的库存文件

[hosts]
10.182.1.23  ansible_connection=ssh ansible_ssh_user=username ansible_ssh_pass=passphrase

我无法理解它如何能够连接到主机以获得前两个任务以及为什么它会为第三个任务引发错误。 我是使用Ansible的新手。请帮帮我。

2 个答案:

答案 0 :(得分:2)

  

我的剧本中有三个任务。对于所有这些,Ansible需要连接到清单文件中指定的主机。

那不是真的。所有查找插件都在控制计算机上本地执行其操作。

"Lookups: Like all templating, these plugins are evaluated on the Ansible control machine"

  

我无法理解它如何能够连接到主机以执行前两项任务以及为什么它会为第三项任务引发错误。

因为您的前两个任务使用带有查找插件的 #nav li a:hover { color: yellow; font-style: italic; } #nav li a:active { color: blue; font-style: italic; } 模块。它们只是将debug参数的值打印到输出,并且不需要连接到远程主机。

因此,您的前两个任务会显示本地文件msg的内容和本地日期时间。

第三个任务尝试在目标计算机上运行代码并且无法连接。

答案 1 :(得分:0)

尝试使用linux命令来确定ssh是否完美无缺。

ssh remoteuser@remoteserver

不应提示输入密码。