Docker容器网络代理设置

之前已经讲过如何设置Docker守护进程如何设置网络代理,那么如何设置运行的Docker容器的网络代理呢?

设置环境变量

设置容器环境变量,这也是最直接的一种方式。启动容器时,通过设置–env的flag,将环境变量传入容器。

变量名

Dockerfile示例

Docker run示例

HTTP_PROXY

ENV HTTP_PROXY “http://127.0.0.1:3001”

–env HTTP_PROXY=“http://127.0.0.1:3001”

HTTPS_PROXY

ENV HTTPS_PROXY “https://127.0.0.1:3001”

–env HTTPS_PROXY=“https://127.0.0.1:3001”

FTP_PROXY

ENV FTP_PROXY “ftp://127.0.0.1:3001”

–env FTP_PROXY=“ftp://127.0.0.1:3001”

NO_PROXY

ENV NO_PROXY “*.test.example.com,.example2.com”

–env NO_PROXY=“*.test.example.com,.example2.com”

这种方式的优点就是直接,但缺点就是每次启动容器,都需要显示的设置,那么编译一些项目就会遇到麻烦。比如kubevirt项目,会在代码中启动容器下载go项目,需要用到代理,那就必须手动找到启动容器的位置,显示加上以上的环境变量,增加了很多工作量。为了解决这种情况,在Docker 17.07以上,可以使用配置Docker客户端的方式。

配置Docker客户端

前置条件:Docker 17.07以上。
  在启动docker用户的Home目录,创建~/.docker/config.json文件,增加http_proxy、https_proxy、ftp_proxy等的设置。当然,也可以同时配置多个代理服务器。
  对于不想使用no_proxy的路径,也可以增加no_proxy的配置,no_proxy的内容用逗号分隔,而且支持通配符*。
  示例:

{
 "proxies":
 {
   "default":
   {
     "httpProxy": "http://127.0.0.1:3001",
     "httpsProxy": "http://127.0.0.1:3001",
     "noProxy": "*.test.example.com,.example2.com"
   }
 }
}

启动容器,即可看到容器内会被自动加入代理。

你可能感兴趣的:(java,docker,网络,容器,运维,elasticsearch)