首页 文章

无法在代理后面下载Docker镜像

提问于
浏览
233

我在我的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 回答

  • 1

    如果您在Ubuntu中,请执行这些命令以添加代理 .

    sudo nano /etc/default/docker
    

    并取消注释指定的行

    #export http_proxy = http://username:password@10.0.1.150:8050
    

    并用适当的代理服务器和用户名替换它 .

    然后重启Docker:

    service docker restart
    

    现在您可以在代理后面运行Docker命令:

    docker search ubuntu
    
  • 1

    如果您使用的是Ubuntu,则应执行以下命令:

    export https_proxy=http://your_name:password@ip_proxy:port docker
    

    并重新加载Docker:

    service docker.io restart
    

    或者用纳米去 /etc/docker.io

  • 1

    由于我不允许发表评论:

    对于CentOS 7,我需要在"docker.service"中激活EnvironmentFile,如下所述:Control and configure Docker with systemd .

    编辑:我正在添加我的解决方案,如Nilesh所述 . 我需要打开“/etc/systemd/system/docker.service”并且我必须在该部分中添加

    [服务] EnvironmentFile = - / etc / sysconfig / docker

    只有这样,我的系统上才加载了“etc / sysconfig / docker”文件 .

  • 0

    在使用Docker 1.9.1的Ubuntu 14.04(Trusty Tahr)上,我只是取消注释 http_proxy 行,更新了值,然后重新启动了Docker服务 .

    export http_proxy="http://proxy.server.com:80"
    

    然后

    service docker restart
    
  • 32

    为了扩展Arun上面的答案,为了在CentOS 7中工作,我不得不删除“export”命令 . 所以编辑

    /etc/sysconfig/docker
    

    并添加:

    HTTP_PROXY="http://<proxy_host>:<proxy_port>"
    HTTPS_PROXY="https://<proxy_host>:<proxy_port>"
    http_proxy="${HTTP_PROXY}"
    https_proxy="${HTTPS_PROXY}"
    

    然后重启Docker:

    sudo service docker restart
    

    source is this blog post .

  • 0

    在RHEL6.6上只有这个工作(注意使用 export ):

    /etc/sysconfig/docker

    export http_proxy="http://myproxy.example.com:8080"
    export https_proxy="http://myproxy.example.com:8080"
    

    注意:两者都可以使用 http 协议 . )

    感谢https://crondev.com/running-docker-behind-proxy/

  • 86

    以下是代理HTTP的官方Docker文档的链接:https://docs.docker.com/config/daemon/systemd/#httphttps-proxy

    快速概述:

    首先,为Docker服务创建一个systemd插件目录:

    mkdir /etc/systemd/system/docker.service.d
    

    现在创建一个名为 /etc/systemd/system/docker.service.d/http-proxy.conf 的文件,它添加 HTTP_PROXY 环境变量:

    [Service]
    Environment="HTTP_PROXY=http://proxy.example.com:80/"
    

    如果您有内部Docker注册表,您需要联系而无需代理,您可以通过 NO_PROXY 环境变量指定它们:

    Environment="HTTP_PROXY=http://proxy.example.com:80/"
    Environment="NO_PROXY=localhost,127.0.0.0/8,docker-registry.somecorporation.com"
    

    同花顺变化:

    $ sudo systemctl daemon-reload
    

    验证是否已加载配置:

    $ sudo systemctl show --property Environment docker
    Environment=HTTP_PROXY=http://proxy.example.com:80/
    

    重启Docker:

    $ sudo systemctl restart docker
    
  • 0

    您的APT代理设置与Docker无关 .

    Docker使用HTTP_PROXY环境变量(如果存在),例如:

    sudo HTTP_PROXY=http://192.168.1.1:3128/ docker pull busybox
    

    但相反,我建议您查看一下 /etc/default/docker 配置文件:您应该有一行来取消注释(并可能调整)以自动应用您的代理设置 . 然后重启Docker服务器:

    service docker restart
    
  • 11

    在CentOS上,Docker的配置文件位于:

    / etc / sysconfig / docker

    添加以下行帮助我让Docker守护程序在代理服务器后面工作:

    HTTP_PROXY="http://<proxy_host>:<proxy_port>"
    HTTPS_PROXY="http://<proxy_host>:<proxy_port>"
    
  • 561

    在Ubuntu上,您需要为Docker守护进程设置http_proxy,而不是客户端进程 . 这在 /etc/default/docker 中完成(参见here) .

  • 51

    如果您使用的是新的 Docker for Mac (或 Docker for Windows ),只需右键单击Docker托盘图标并选择“首选项”(Windows:设置),然后转到“高级”,然后在“代理”下指定代理设置 . 单击Apply并重新启动并等待Docker重新启动 .

  • 24

    为什么本地绑定的代理不起作用

    问题

    如果您正在运行本地绑定的代理,例如听 127.0.0.1:8989 ,它不会在 Docker for Mac 中工作 . 来自Docker documentation

    我想从容器连接到主机上的服务Mac具有更改的IP地址(如果您没有网络访问权限,则为无) . 我们目前的建议是将未使用的IP连接到Mac上的lo0接口;例如:sudo ifconfig lo0别名10.200.10.1/24,并确保您的服务正在侦听此地址或0.0.0.0(即不是127.0.0.1) . 然后容器可以连接到此地址 .

    类似的是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

    sudo ifconfig lo0 alias 10.200.10.1/24
    
    • 在Docker托盘菜单中的“首选项”中将HTTP和/或HTTPS代理设置为 10.200.10.1:8989 (假设代理服务器正在侦听端口 8989 ) .

    之后,通过从未下载的映像在新容器中运行命令来测试代理设置:

    $ docker rmi -f hello-world
      ...
    
    $ docker run hello-world
    Unable to find image 'hello-world:latest' locally
    latest: Pulling from library/hello-world
    
    c04b14da8d14: Pull complete 
    Digest: sha256:0256e8a36e2070f7bf2d0b0763dbabdd67798512411de4cdcf9431a1feb60fd9
    Status: Downloaded newer image for hello-world:latest
      ...
    

    Notice: ifconfig 设置的环回别名在重启后不会保留 . 使其持久化是另一个话题 . 请用日语检查this blog post(谷歌翻译可能有帮助) .

  • 9

    这是对我有用的修复:Ubuntu,Docker版本:1.6.2

    在文件 /etc/default/docker 中,添加以下行:

    export http_proxy='http://<host>:<port>'
    

    重启Docker

    sudo service docker restart
    
  • 6

    要将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):

    HTTPS_PROXY="https://<user>:<password>@<proxy-host>:<proxy-port>"
    HTTP_PROXY="https://<user>:<password>@<proxy-host>:<proxy-port>"
    export HTTP_PROXY="https://<user>:<password>@<proxy-host>:<proxy-port>"
    export HTTPS_PROXY="https://<user>:<password>@<proxy-host>:<proxy-port>"
    

    Docker存储库(Docker Hub)仅支持HTTPS . 要使Docker使用SSL拦截代理,您必须将代理根证书添加到系统信任库 .

    对于CentOS,将文件复制到 /etc/pki/ca-trust/source/anchors/ 并更新CA信任库并重新启动Docker服务 .

    如果您的代理使用NTLMv2身份验证 - 您需要使用中间代理(如Cntlm)来桥接身份验证 . This blog post explains it in detail .

  • 4

    安装Docker后,请执行以下操作:

    [mdesales@pppdc9prd1vq ~]$ sudo HTTP_PROXY=http://proxy02.ie.xyz.net:80 ./docker -d &
    [2] 20880
    

    然后,你可以拉或做任何事情:

    mdesales@pppdc9prd1vq ~]$ sudo docker pull base
    2014/04/11 00:46:02 POST /v1.10/images/create?fromImage=base&tag=
    [/var/lib/docker|aa088847] +job pull(base, )
    Pulling repository base
    b750fe79269d: Download complete
    27cf78414709: Download complete
    [/var/lib/docker|aa088847] -job pull(base, ) = OK (0)
    
  • 3

    在新版本的Docker中, docker-engine ,在基于 systemd 的发行版中,您应该将环境变量行添加到/lib/systemd/system/docker.service,如上所述由他人:

    Environment="HTTP_PROXY=http://hostname_or_ip:port/"
    
  • 3

    为了解决Docker构建中的curl问题,我在Dockerfile中添加了以下内容:

    ENV http_proxy=http://infoprx2:8080
    ENV https_proxy=http://infoprx2:8080
    RUN apt-get update && apt-get install -y curl vim
    

    请注意,ENV语句是在RUN语句之前 .

    为了使Docker守护进程能够访问Internet(我使用Kitematic和boot2docker),我将以下内容添加到 /var/lib/boot2docker/profile 中:

    export HTTP_PROXY=http://infoprx2:8080
    export HTTPS_PROXY=http://infoprx2:8080
    

    然后我用 sudo /etc/init.d/docker restart 重新启动了Docker .

  • 2

    也许您需要设置小写变量 . 就我而言,我的 /etc/systemd/system/docker.service.d/http-proxy.conf 文件看起来像这样:

    [Service]
    Environment="ftp_proxy=http://<user>:<password>@<proxy_ip>:<proxy_port>/"
    Environment="http_proxy=http://<user>:<password>@<proxy_ip>:<proxy_port>/"
    Environment="https_proxy=http://<user>:<password>@<proxy_ip>:<proxy_port>/"
    

    祝好运! :)

  • 2

    简单地设置代理环境变量在版本1.0.1中没有帮助我...我必须使用"http_proxy"变量的正确值更新 /etc/default/docker.io 文件 .

  • 2

    如果使用socks5代理,这是我的Docker 17.03.1-ce测试设置“all_proxy”,它工作:

    # Set up socks5 proxy server
    ssh sshUser@proxyServer -C -N -g -D \
         proxyServerIp:9999 \
         -o ExitOnForwardFailure=yes \
         -o ServerAliveInterval=60
    
    # Configure dockerd and restart.
    # NOTICE: using "all_proxy"
    mkdir -p /etc/systemd/system/docker.service.d
    cat > /etc/systemd/system/docker.service.d/http-proxy.conf <<EOF
    [Service]
    Environment="all_proxy=socks5://proxyServerIp:9999"
    Environment="NO_PROXY=localhost,127.0.0.1,private.docker.registry.com"
    EOF
    
    systemctl daemon-reload
    systemctl restart docker
    
    # Test whether can pull images
    docker run -it --rm alpine:3.5
    
  • 26

    在我的网络中,Ubuntu在企业ISA代理服务器后面工作 . 它需要身份验证 . 我尝试了上面提到的所有解决方案并没有任何帮助真正有用的是在没有域名的情况下在文件 /etc/systemd/system/docker.service.d/https-proxy.conf 中编写代理行 .

    代替

    Environment="HTTP_PROXY=http://user@domain:password@proxy:8080"
    

    要么

    Environment="HTTP_PROXY=http://domain\user:password@proxy:8080"
    

    和其他一些替代品,如 @ -> %40\ -> \\ 我试过用

    Environment="HTTP_PROXY=http://user:password@proxy:8080"
    

    它现在有效 .

  • 2

    试试这个:

    sudo HTTP_PROXY=http://<IP address of proxy server:port> docker -d &
    

相关问题