Python docker-py连接被拒绝

时间:2015-04-17 15:21:25

标签: python docker dockerpy

我在使用Python中的docker-py从客户端访问docker守护程序时遇到问题。我通过命令启动了一个docker守护进程 sudo docker -d &,输出为[1] 4894。然后我尝试使用我从here以root身份获得的代码从python访问守护进程

from docker import Client
cli = Client(base_url='unix://var/run/docker.sock')
cli.containers()

这给了我错误:

requests.exceptions.ConnectionError: ('Connection aborted.', error(111, 'Connection refused'))

我也试过

cli = Client(base_url='tcp://127.0.0.1:4894') 

但它给了我同样的错误。

2 个答案:

答案 0 :(得分:10)

这似乎是/var/run/docker.sock文件具有不正确的权限。由于docker守护程序以root身份启动,因此权限可能具有限制性。

如果您更改权限以允许其他用户访问它,您应该获得更多成功(例如o = rwx)。

答案 1 :(得分:0)

问题确实是 /var/run/docker.sock 的权限不正确。 要修复它,您需要授予当前用户访问此文件的权限。

但是,在 Linux 上,将 o=rwx 权限授予 /var/run/docker.sock 是非常危险的,因为它允许系统上的任何用户和服务以 root 身份运行命令。实际上,对 /var/run/docker.sock 的访问意味着对机器的完全根访问权限。见https://docs.docker.com/engine/security/#docker-daemon-attack-surface

一种不太危险的方法是创建组 docker 并将当前用户添加到该组。见https://docs.docker.com/engine/install/linux-postinstall/#manage-docker-as-a-non-root-user

然而,这种方法仍然存在潜在危险,因为它在没有 sudo 提供的保护(即不时询问用户密码并记录 sudo 调用)的情况下为当前用户提供了完全的 root 访问权限。

另见What is the Docker security risk of /var/run/docker.sock?

(不幸的是,我无法发表评论,因此我写下我的评论作为答案。)