我创建了一个开放端口 22 的 ec2 实例,我可以使用终端上的私钥连接到该实例,但是,当我尝试 ansible-playbook 时,我无法连接它。我一直在使用动态库存。
我用于 SSH 的命令也很成功(我正在运行以下放置私钥的命令):
ssh -i "test-key.pem" [email protected]
剧本内容:
---
- name: Hello World example
hosts: all
become: true
tasks:
- name: Printing Hello World
debug:
msg: "Hello World"
我运行的命令:
ansible-playbook -i ec2.py --private-key /home/testuser/.ssh/test-key.pem -l instance_id playbook-hello.yml
即使我尝试过:
ansible-playbook -i ec2.py --private-key /home/testuser/.ssh/test-key.pem -l instance_id -e 'ansible_ssh_user=ubuntu' playbook-hello.yml
错误:
fatal: [x.x.x.x]: UNREACHABLE! => {"changed": false, "msg": "Failed to connect to the host via ssh: ssh: connect to host x.x.x.x port 22: Operation timed out\r\n", "unreachable": true}
其他详情:
我在我的 MacBook Pro 上运行 ansible-playbooks。EC2 实例正在运行 Ubuntu OS 18.04。
当我运行 ./ec2.py - 我可以看到我的实例正在打印。AWS 密钥保存在主目录 .aws/credentials 文件夹中。
PS: 这个问题可能与其他可用问题重复,但我没有得到任何与我的案例相匹配的积极见解。
我很难理解使用的 ec2.py 脚本只返回具有私有 IP 的实例。因此,它无法连接到端口 22 上的实例。
但是,当我使用 ssh 时,我使用的是公共 IP 或 DNS 名称。
因此,我没有使用 ec2.py,而是使用公共 IP 执行脚本:
abcd -- 是实例的公共 IP。
如果任何人有以下错误:
请使用以下命令:
只需确保 pythos3 安装在您尝试执行 playbook 的实例的上述路径上。