在一些實驗環境,服務器沒有直接連接萬網的權限,需要通過網絡代理;通常情況下將網絡代理直接配置在/etc/envrionment、/etc/profile之類的配置文件中,這對于大部分操作都是可行的。然而,docker命令卻不能使用這些代理。最典型場景就是docker需要從外網pull鏡像;
下面推薦一種方法,修改后會一直生效,該方法覆蓋了默認的docker.service文件;
1、為docker服務創建一個內嵌的systemd目錄
mkdir -p /etc/systemd/system/docker.service.d
2、設置代理
創建/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]/"
如果還有內部的不需要使用代理來訪問的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"
3、更新配置
systemctl daemon-reload
4、重啟Docker服務
systemctl restart docker
5. 確認設置已生效
$ systemctl show --property=Environment docker
Environment=HTTP_PROXY=http://proxy.example.com:80/
6.引用
https://docs.docker.com/engine/admin/systemd/#httphttps-proxy