博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Docker网络代理设置
阅读量:3591 次
发布时间:2019-05-20

本文共 3584 字,大约阅读时间需要 11 分钟。

Docker网络代理设置

一:背景

在一些实验室环境,服务器没有直接连接外网的权限,需要通过网络代理。我们通常会将网络代理直接配置在/etc/environment、/etc/profile之类的配置文件中,这对于大部分操作都是可行的。然而,docker命令却使用不了这些代理。比如docker pull时需要从外网下载镜像,就会出现如下错误:

$ docker pull hello-world Unable to find image 'hello-world:latest' locallyPulling repository docker.io/library/hello-worlddocker: Network timed out while trying to connect to https://index.docker.io/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'.

本文在Ubuntu16.04下测试通过。

二:解决方案一

停止docker服务,手动以使用2375端口监听所有网络接口的方式启动docker daemon。

$ systemctl stop docker.service$ nohup docker daemon -H tcp://0.0.0.0:2375 -H unix:///var/run/docker.sock  &

详情参见:https://docs.docker.com/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

四:解决方案三

该方法是持久化的,修改后会一直生效。该方法覆盖了默认的docker.service文件。

  1. 为docker服务创建一个内嵌的systemd目录
$ mkdir -p /etc/systemd/system/docker.service.d
  1. 创建/etc/systemd/system/docker.service.d/http-proxy.conf文件,并添加HTTP_PROXY环境变量。其中[proxy-addr]和[proxy-port]分别改成实际情况的代理地址和端口:
[Service]Environment="HTTP_PROXY=http://[proxy-addr]:[proxy-port]/" "HTTPS_PROXY=https://[proxy-addr]:[proxy-port]/"
  1. 如果还有内部的不需要使用代理来访问的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,docker-registry.somecorporation.com"
  1. 更新配置:
$ systemctl daemon-reload
  1. 重启Docker服务:
$ systemctl restart docker

详情参见:https://docs.docker.com/engine/admin/systemd/#http-proxy

五:使用socks5代理

vim /usr/lib/systemd/system/docker.service[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,m1empwb1.mirror.aliyuncs.com,docker.io,registry.cn-hangzhou.aliyuncs.com
[root@cloud4ourself-kcluster1 system]# systemctl daemon-reload[root@cloud4ourself-kcluster1 system]# systemctl show docker |grep 127.0.0.1Environment=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,m1empwb1.mirror.aliyuncs.com,docker.io,registry.cn-hangzhou.aliyuncs.com[root@cloud4ourself-kcluster1 system]# systemctl restart docker

测试

[root@cloud4ourself-kcluster1 ~]# docker pull gcr.io/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))

转载地址:http://bzvwn.baihongyu.com/

你可能感兴趣的文章
第二次实习的实习总结
查看>>
PPT的一些常用操作
查看>>
Java面试题解析(基础篇,附答案)
查看>>
Spring 常用的三种注入方式
查看>>
MyBatis 一级缓存在分布式下的坑你知道吗?
查看>>
2020年2月JVM面试的30个知识点
查看>>
在家办公7天整理Spring Cloud知识点大全
查看>>
看看这些Java代码开发规范吧!你好,我好,大家好!
查看>>
2020年3月,47个经典Spring面试题详解(附带答案)
查看>>
python实现Mapreduce的wordcount
查看>>
Linux字符设备驱动编(步骤,框架(面向对象),分层)
查看>>
linux高级字符驱动之输入子系统
查看>>
代理与反射
查看>>
面向对象
查看>>
训练并导出tensorflow Lite模型中的一些问题 及解决办法
查看>>
QQ小程序百度网盘中的文件保存和下载
查看>>
34个数据库常见面试题讲解
查看>>
什么是存储过程
查看>>
面试题4
查看>>
IOCP模型与网络编程
查看>>