背景
在一些实验室环境,服务器没有直接连接外网的权限,需要通过网络代理。我们通常会将网络代理直接配置在/etc/environment、/etc/profile之类的配置文件中,这对于大部分操作都是可行的。然而,docker命令却使用不了这些代理。比如docker pull时需要从外网下载镜像,就会出现如下错误:
$ docker pull hello-world
Unable to find image 'hello-world:latest' locally
Pulling repository /library/hello-world
docker: Network timed out while trying to connect to /v1/repositories/library/hello-world/images. You may want to check your internet connection or if you are behind a proxy..
See 'docker run --help'.
ps: 本文在Ubuntu16.04下测试通过。
解决方案一:
停止docker服务,手动以使用2375端口监听所有网络接口的方式启动docker daemon。
$ systemctl stop
$ nohup docker daemon -H tcp://0.0.0.0:2375 -H unix:///var/run/ &
详情参见:/v1.11/engine/reference/commandline/daemon/#daemon-socket-option
解决方案二:
编辑配置文件,Ubuntu下是/etc/default/docker,CentOS下是/etc/sysconfig/docker。不过通过修改这两个文件来配置daemon已经是discouraged的了。不鼓励使用这种方法。
HTTP_PROXY="http://[proxy-addr]:[proxy-port]/"
HTTPS_PROXY="https://[proxy-addr]:[proxy-port]/"
export HTTP_PROXY HTTPS_PROXY
解决方案三:
该方法是持久化的,修改后会一直生效。该方法覆盖了默认的文件。
1. 为docker服务创建一个内嵌的systemd目录
$ mkdir -p /etc/systemd/system/
2. 创建/etc/systemd/system//文件,并添加HTTP_PROXY环境变量。其中[proxy-addr]和[proxy-port]分别改成实际情况的代理地址和端口:
[Service]
Environment="HTTP_PROXY=http://[proxy-addr]:[proxy-port]/" "HTTPS_PROXY=https://[proxy-addr]:[proxy-port]/"
3. 如果还有内部的不需要使用代理来访问的Docker registries,那么嗨需要制定NO_PROXY环境变量:
[Service]
Environment="HTTP_PROXY=http://[proxy-addr]:[proxy-port]/" "HTTPS_PROXY=https://[proxy-addr]:[proxy-port]/" "NO_PROXY=localhost,127.0.0.1,"
4. 更新配置:
$ systemctl daemon-reload
5. 重启Docker服务:
$ systemctl restart docker
详情参见:/engine/admin/systemd/#http-proxy
使用socks5代理:
vim /usr/lib/systemd/system/
[Service]下增加
Environment=HTTP_PROXY=http://127.0.0.1:8118/
Environment=HTTPS_PROXY=http://127.0.0.1:8118/
Environment=NO_PROXY=localhost,127.0.0.1,,,
[root@cloud4ourself-kcluster1 system]# systemctl daemon-reload
[root@cloud4ourself-kcluster1 system]# systemctl show docker |grep 127.0.0.1
Environment=GOTRACEBACK=crash HTTP_PROXY=http://127.0.0.1:8118/ HTTPS_PROXY=http://127.0.0.1:8118/ NO_PROXY=localhost,127.0.0.1,,,
[root@cloud4ourself-kcluster1 system]# systemctl restart docker
测试
[root@cloud4ourself-kcluster1 ~]# docker pull /kubernetes-helm/tiller:v2.2.2
[root@cloud4ourself-kcluster1 ~]# ss -antp |grep EST |egrep '1080|8118'
ESTAB 0 0 127.0.0.1:8118 127.0.0.1:49807 users:(("privoxy",pid=30250,fd=11))
ESTAB 0 0 127.0.0.1:1080 127.0.0.1:34849 users:(("sslocal",pid=19727,fd=10))
ESTAB 0 0 127.0.0.1:49824 127.0.0.1:8118 users:(("docker-current",pid=15419,fd=72))
ESTAB 0 0 127.0.0.1:49807 127.0.0.1:8118 users:(("docker-current",pid=15419,fd=140))
ESTAB 0 0 127.0.0.1:34849 127.0.0.1:1080 users:(("privoxy",pid=30250,fd=7))
ESTAB 0 0 127.0.0.1:34866 127.0.0.1:1080 users:(("privoxy",pid=30250,fd=6))
ESTAB 0 0 127.0.0.1:1080 127.0.0.1:34866 users:(("sslocal",pid=19727,fd=9))
ESTAB 0 0 127.0.0.1:8118 127.0.0.1:49824 users:(("privoxy",pid=30250,fd=5))