我在我的Ubuntu 13.10(Saucy Salamander)上安装了Docker,当我输入我的控制台时:
sudo docker pull busybox
我收到以下错误:
Pulling repository busybox
2014/04/16 09:37:07 Get https://index.docker.io/v1/repositories/busybox/images: dial tcp: lookup index.docker.io on 127.0.1.1:53: no answer from server
Docker版本:
$ sudo docker version
Client version: 0.10.0
Client API version: 1.10
Go version (client): go1.2.1
Git commit (client): dc9c28f
Server version: 0.10.0
Server API version: 1.10
Git commit (server): dc9c28f
Go version (server): go1.2.1
Last stable version: 0.10.0
我在没有身份验证的代理服务器后面,这是我的 /etc/apt/apt.conf
文件:
Acquire::http::proxy "http://192.168.1.1:3128/";
Acquire::https::proxy "https://192.168.1.1:3128/";
Acquire::ftp::proxy "ftp://192.168.1.1:3128/";
Acquire::socks::proxy "socks://192.168.1.1:3128/";
我究竟做错了什么?
22 回答
如果您在Ubuntu中,请执行这些命令以添加代理 .
并取消注释指定的行
并用适当的代理服务器和用户名替换它 .
然后重启Docker:
现在您可以在代理后面运行Docker命令:
如果您使用的是Ubuntu,则应执行以下命令:
并重新加载Docker:
或者用纳米去
/etc/docker.io
由于我不允许发表评论:
对于CentOS 7,我需要在"docker.service"中激活EnvironmentFile,如下所述:Control and configure Docker with systemd .
编辑:我正在添加我的解决方案,如Nilesh所述 . 我需要打开“/etc/systemd/system/docker.service”并且我必须在该部分中添加
只有这样,我的系统上才加载了“etc / sysconfig / docker”文件 .
在使用Docker 1.9.1的Ubuntu 14.04(Trusty Tahr)上,我只是取消注释
http_proxy
行,更新了值,然后重新启动了Docker服务 .然后
为了扩展Arun上面的答案,为了在CentOS 7中工作,我不得不删除“export”命令 . 所以编辑
并添加:
然后重启Docker:
source is this blog post .
在RHEL6.6上只有这个工作(注意使用
export
):/etc/sysconfig/docker
注意:两者都可以使用
http
协议 . )感谢https://crondev.com/running-docker-behind-proxy/
以下是代理HTTP的官方Docker文档的链接:https://docs.docker.com/config/daemon/systemd/#httphttps-proxy
快速概述:
首先,为Docker服务创建一个systemd插件目录:
现在创建一个名为
/etc/systemd/system/docker.service.d/http-proxy.conf
的文件,它添加HTTP_PROXY
环境变量:如果您有内部Docker注册表,您需要联系而无需代理,您可以通过
NO_PROXY
环境变量指定它们:同花顺变化:
验证是否已加载配置:
重启Docker:
您的APT代理设置与Docker无关 .
Docker使用HTTP_PROXY环境变量(如果存在),例如:
但相反,我建议您查看一下
/etc/default/docker
配置文件:您应该有一行来取消注释(并可能调整)以自动应用您的代理设置 . 然后重启Docker服务器:在CentOS上,Docker的配置文件位于:
添加以下行帮助我让Docker守护程序在代理服务器后面工作:
在Ubuntu上,您需要为Docker守护进程设置http_proxy,而不是客户端进程 . 这在
/etc/default/docker
中完成(参见here) .如果您使用的是新的 Docker for Mac (或 Docker for Windows ),只需右键单击Docker托盘图标并选择“首选项”(Windows:设置),然后转到“高级”,然后在“代理”下指定代理设置 . 单击Apply并重新启动并等待Docker重新启动 .
为什么本地绑定的代理不起作用
问题
如果您正在运行本地绑定的代理,例如听
127.0.0.1:8989
,它不会在 Docker for Mac 中工作 . 来自Docker documentation:类似的是Docker服务器端 . (要了解Docker的服务器端和客户端,请尝试运行
docker version
. )服务器端运行在具有自己的localhost
的虚拟化层上 . 因此,它不会连接到主机OS的localhost
上的代理服务器 .解决方案
所以,如果你使用像我这样的本地绑定代理,基本上你必须做以下事情才能使它适用于Docker for Mac:
使您的代理服务器侦听
0.0.0.0
而不是127.0.0.1
. Caution: 您需要适当的防火墙配置以防止恶意访问它 .为
lo0
接口添加环回别名,例如10.200.10.1/24
:10.200.10.1:8989
(假设代理服务器正在侦听端口8989
) .之后,通过从未下载的映像在新容器中运行命令来测试代理设置:
Notice:
ifconfig
设置的环回别名在重启后不会保留 . 使其持久化是另一个话题 . 请用日语检查this blog post(谷歌翻译可能有帮助) .这是对我有用的修复:Ubuntu,Docker版本:1.6.2
在文件
/etc/default/docker
中,添加以下行:重启Docker
要将Docker配置为使用代理,您需要将HTTPS_PROXY / HTTP_PROXY环境变量添加到Docker sysconfig文件(
/etc/sysconfig/docker
) .根据您是否使用
init.d
或服务工具,您需要添加"export"语句(由于Debian Bug report logs - #767441. Examples in /etc/default/docker are misleading regarding the supported syntax):Docker存储库(Docker Hub)仅支持HTTPS . 要使Docker使用SSL拦截代理,您必须将代理根证书添加到系统信任库 .
对于CentOS,将文件复制到
/etc/pki/ca-trust/source/anchors/
并更新CA信任库并重新启动Docker服务 .如果您的代理使用NTLMv2身份验证 - 您需要使用中间代理(如Cntlm)来桥接身份验证 . This blog post explains it in detail .
安装Docker后,请执行以下操作:
然后,你可以拉或做任何事情:
在新版本的Docker中, docker-engine ,在基于 systemd 的发行版中,您应该将环境变量行添加到/lib/systemd/system/docker.service,如上所述由他人:
为了解决Docker构建中的curl问题,我在Dockerfile中添加了以下内容:
请注意,ENV语句是在RUN语句之前 .
为了使Docker守护进程能够访问Internet(我使用Kitematic和boot2docker),我将以下内容添加到
/var/lib/boot2docker/profile
中:然后我用
sudo /etc/init.d/docker restart
重新启动了Docker .也许您需要设置小写变量 . 就我而言,我的 /etc/systemd/system/docker.service.d/http-proxy.conf 文件看起来像这样:
祝好运! :)
简单地设置代理环境变量在版本1.0.1中没有帮助我...我必须使用"http_proxy"变量的正确值更新
/etc/default/docker.io
文件 .如果使用socks5代理,这是我的Docker 17.03.1-ce测试设置“all_proxy”,它工作:
在我的网络中,Ubuntu在企业ISA代理服务器后面工作 . 它需要身份验证 . 我尝试了上面提到的所有解决方案并没有任何帮助真正有用的是在没有域名的情况下在文件
/etc/systemd/system/docker.service.d/https-proxy.conf
中编写代理行 .代替
要么
和其他一些替代品,如
@ -> %40
或\ -> \\
我试过用它现在有效 .
试试这个: