docker - Docker容器中的Ansible无法通过SSH连接到Hetzner主机

标签 docker ssh ansible windows-10

我是Ansible的新手,我正在尝试使用Docker(Windows 10)运行剧本,但无法将ssh放入Hetzner云中。
我创建了一个Makefile在Docker中运行Ansible

# Makefile
run_playbook:
    @docker run --rm \
        -v "C:/Users/myuser/.ssh/hetzner/id_rsa:/root/.ssh/id_rsa" \
        -v "C:/Users/myuser/.ssh/hetzner/id_rsa.pub:/root/.ssh/id_rsa.pub" \
        -v $(CURDIR)/ansible.cfg:/etc/ansible/ansible.cfg \
        -v $(CURDIR):/myapp-ansible \
        -w /myapp-ansible \
        williamyeh/ansible:alpine3 \
        ansible-playbook -i staging site.yml -vvv
这是staging库存
[myapp]
<HETNER_SERVER_NAME> ansible_host=<HETZNER_SERVER_IP> ansible_user=root
这是ansible.cfg
# ansible.cfg
[defaults]
host_key_checking = false
roles_path = /myapp-ansible/roles

[privilege_escalation]
become = True
become_method = sudo
become_user = root
问题是,当我运行make run_playbook命令时,出现错误Failed to connect to the host via ssh
所以我尝试从docker容器手动连接以查看发生了什么,这就是结果
@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
@         WARNING: UNPROTECTED PRIVATE KEY FILE!          @
@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
Permissions 0755 for '/root/.ssh/id_rsa' are too open.
It is required that your private key files are NOT accessible by others.
This private key will be ignored.
Load key "/root/.ssh/id_rsa": bad permissions
root@<HETZNER_SERVER_IP>'s password:
我试图用id_rsa更改sudo chmod 600 /root/.ssh/id_rsa权限,但似乎没有效果
$ ls -l /root/.ssh
-rwxr-xr-x    1 root     root          2610 Aug 25 13:38 id_rsa
-rwxr-xr-x    1 root     root           577 Aug 25 13:38 id_rsa.pub
-rw-r--r--    1 root     root           176 Aug 26 08:42 known_hosts
因此,我尝试按照建议的here在Windows中直接更改id_rsa权限,但是得到的结果与以前相同。
要注意的是,在Windows中,我可以使用具有相同私钥的Putty进行ssh操作而不会出现问题。
提前致谢

最佳答案

大量搜索之后,我发现this article,所以我如下更改了run_playbook:

run_playbook:
    @docker run -t --rm \
        -v "C:/Users/myuser/.ssh/hetzner/id_rsa:/tmp/.ssh/id_rsa" \
        -v "C:/Users/myuser/.ssh/hetzner/id_rsa.pub:/tmp/.ssh/id_rsa.pub" \
        -v $(CURDIR):/myapp-ansible \
        -w /myapp-ansible \
        williamyeh/ansible:alpine3 \
        /bin/sh -c "cp -R /tmp/.ssh /root/.ssh && chmod 700 /root/.ssh && chmod 644 /root/.ssh/id_rsa.pub && chmod 600 /root/.ssh/id_rsa"
        ansible-playbook -i staging site.yml

关于docker - Docker容器中的Ansible无法通过SSH连接到Hetzner主机,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63594269/

相关文章:

docker - 使docker-compose运行唯一的链接容器

c - 通过 ssh 替换并打开 stdin/stdout

macos - 为什么 Jenkins 在传递 key 后仍然要求 ssh 密码?

database - 如何通过使用docker在postGIS数据库中修复 “unknown authentication response: 10”

docker - 无法从前端解析 docker compose 服务名称

docker - 谁能让我知道我的docker文件中的问题是什么?

shell - 无法解析 GitLab 的主机名

json - 当值包含ansible中的字符串时解析json值

ansible - 如何使用 ansible 的剧本设置默认路径?

kubernetes - Ansible:无法重新加载sysctl:sysctl:无法统计/proc/sys/net/bridge/bridge-nf-call-iptables:没有这样的文件或目录