Vagrant / Ansible SSH错误

时间:2017-02-22 18:54:16

标签: azure ssh vagrant ansible

尝试使用Vagrant和Ansible配置Azure VM时出现以下错误:

    ➜  remote-dev git:(master) ✗ vagrant provision app
    ==> app: Running provisioner: ansible...
        app: Running ansible-playbook...
    PYTHONUNBUFFERED=1 ANSIBLE_FORCE_COLOR=true ANSIBLE_HOST_KEY_CHECKING=false ANSIBLE_SSH_ARGS='-o UserKnownHostsFile=/        dev/null -o IdentitiesOnly=yes -o ControlMaster=auto -o ControlPersist=60s' ansible-playbook --connection=ssh --timeout=30 --limit="app"         --inventory-file=/Users/user/vagrant/remote-dev/.vagrant/provisioners/ansible/inventory -vvvv site.yml
    Using /Users/user/vagrant/remote-dev/ansible.cfg as config file
    Loading callback plugin default of type stdout, v2.0 from /usr/local/Cellar/ansible/2.2.0.0_2/libexec/lib/python2.7/site-packages/ansible/plugins/        callback/__init__.pyc

    PLAYBOOK: site.yml *************************************************************
    1 plays in site.yml

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

    TASK [setup] *******************************************************************
    Using module file /usr/local/Cellar/ansible/2.2.0.0_2/libexec/lib/python2.7/site-packages/ansible/modules/core/system/setup.py
    <name.eastus.cloudapp.azure.com> ESTABLISH SSH CONNECTION FOR USER: vagrant
    <name.eastus.cloudapp.azure.com> SSH: EXEC ssh -vvv -o UserKnownHostsFile=/dev/null -o IdentitiesOnly=yes -o ControlMaster=auto -o         ControlPersist=60s -o StrictHostKeyChecking=no -o Port=22 -o 'IdentityFile="/Users/user/.ssh/vagrant.key"' -o KbdInteractiveAuthentication=no -o         PreferredAuthentications=gssapi-with-mic,gssapi-keyex,hostbased,publickey -o PasswordAuthentication=no -o User=vagrant -o ConnectTimeout=30 -o         ControlPath=/Users/user/.ansible/cp/ansible-ssh-%h-%p-%r name.eastus.cloudapp.azure.com '/bin/sh -c '"'"'sudo -H -S -n -u root /bin/sh -c         '"'"'"'"'"'"'"'"'echo BECOME-SUCCESS-nplltooivdpoedgryzzyimyktrvyeduu; /usr/bin/python'"'"'"'"'"'"'"'"' && sleep 0'"'"''
    fatal: [app]: UNREACHABLE! => {
        "changed": false,
        "msg": "SSH Error: data could not be sent to the remote host. Make sure this host can be reached over ssh",
        "unreachable": true
    }

ping工作:

➜  remote-dev git:(master) ✗ ansible app -m ping
app | SUCCESS => {
   "changed": false,
    "ping": "pong"
}

运行ansible-playbook也是如此:

ansible-playbook appservers.yml

我的主人档案:

app ansible_ssh_host=name.eastus.cloudapp.azure.com ansible_ssh_port=22 ansible_ssh_user='vagrant' ansible_ssh_private_key_file='/Users/user/.ssh/vagrant.key'

1 个答案:

答案 0 :(得分:0)

看起来修正了将control_path = %(directory)s/%%h-%%p-%%r添加到[ssh_connection]下的ansible.cfg的原因。

在运行调试输出中找到的下面复制的完整ansible ssh命令后,我走了那条路线并收到此错误:

debug3: muxserver_listen: temporary control path /Users/<user>/.ansible/cp/<fqdn>
unix_listener: "/Users/<user>/.ansible/cp/<fqdn>" too long for Unix domain socket
 ssh -vvv -o UserKnownHostsFile=/dev/null -o IdentitiesOnly=yes -i
 /Users/<user>/.ssh/vagrant.key -o ForwardAgent=yes -o
 ControlMaster=auto -o ControlPersist=60s -o StrictHostKeyChecking=no
 -o Port=22 -o 'IdentityFile="/Users/<user>/.ssh/vagrant.key"' -o KbdInteractiveAuthentication=no -o
 PreferredAuthentications=gssapi-with-mic,gssapi-keyex,hostbased,publickey
 -o PasswordAuthentication=no -o User=vagrant -o ConnectTimeout=90 -o ControlPath=/Users/<user>/.ansible/cp/<fqdn> '/bin/sh -c'

在ansible issue #11536中找到答案。