프록시 뒤에 Docker 이미지를 다운로드 할 수 없습니다


330

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

도커 버전 :

$ 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/";

내가 뭘 잘못하고 있죠?


6
Windows 사용자 및 boot2docker의 경우 stackoverflow.com/a/29303930/6309
VonC

1
하나의 사소한 세부 사항 : apt는 SOCKS 프록시를 전혀 지원하지 않습니다. 구성표로 Acquire::socks::proxy시작하는 모든 URL에 프록시를 설정하는 것을 의미합니다 socks. 당신이 있기 때문에 sources.list어떤이없는 socks://URL을 해당 행은 완전히 무시됩니다.
Hans-Christoph Steiner

무엇에 대해 docker-compose?
Mohammad Masoumi

답변:


796

다음은 프록시 HTTP에 대한 공식 Docker 설명서에 대한 링크입니다. https://docs.docker.com/config/daemon/systemd/#httphttps-proxy

빠른 개요 :

먼저 Docker 서비스에 대한 시스템 드롭 인 디렉토리를 작성하십시오.

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

3
Docker 1.6.2를 실행하는 Debian Jessie에서 작동합니다. 어떻게 든 편집 /etc/default/docker이 작동하지 않습니다. 아마도 exportCentos에 대해 문서화 된 것과 같이 제거해야 할 것입니다.
neurite

2
이전 SysV의 경우 docs.oracle.com/cd/E37670_01/E37355/html/… 에서와 같이 / etc / sysconfig / docker를 편집하십시오. -Oracle Linux 6.7
SidJ

2
NB : 'daemon-reload'는 도커에 변경 사항을 적용하기에 충분하다고 생각했지만 실제로 sudo systemctl restart docker작동하려면 엄격히 요구됩니다.
Jose Alban

4
우분투 14.04의 경우 @ n3o의 답변을 참조하십시오. 우분투 14.04 systemctl 에는 사용할 수 없으므로 서비스를 시작하는 데 사용 upstart됩니다.
chinmay

4
이제 "프록시 인증 필요"를 반환합니다 ... 사용자 이름과 암호를 구성하는 방법은 무엇입니까?
pinei

88

APT 프록시 설정은 Docker와 관련이 없습니다.

Docker는 HTTP_PROXY 환경 변수가있는 경우이를 사용합니다. 예를 들면 다음과 같습니다.

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

그러나 대신 /etc/default/docker구성 파일을 살펴 보는 것이 좋습니다 . 프록시 설정을 자동으로 적용하려면 주석 처리를 제거 (및 조정 가능)해야합니다. 그런 다음 Docker 서버를 다시 시작하십시오.

service docker restart

8
필자의 경우 / etc / default / docker에는 소문자 예제 (http_proxy)가 포함되어 있지만 작동하는 것을 위해서는 대문자 설정 (HTTP_PROXY)을 추가해야했습니다.
Mekk

docker client에 대해 HTTP_PROXY를 설정해서는 안됩니다
thomas.han

3
docker 1.9.1에서는 작동하지 않습니다. 대신 아래의 답변을 보십시오.
Peter Dotchev

1
apt.dockerproject.org에서 docker를 설치할 때 Ubuntu 14.04에서 작동합니다.
Michael Kopp

1
이것은 데비안 8.8에서 작동하지 않으며 허용 된 답변에 표시된 것처럼 /etc/systemd/system/docker.service.d에 http_proxy를 설정해야합니다
Roman Mik

60

CentOS에서 Docker의 구성 파일은 다음 위치에 있습니다.

/etc/sysconfig/docker

아래 줄을 추가하면 Docker 데몬이 프록시 서버 뒤에서 작동하는 데 도움이되었습니다.

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

7
회사 프록시 뒤에있는 사람들을 위해 export HTTP_PROXY = "http : // <username> : <password> @ <proxy_host> : <proxy_port>"
Nicolas Mommaerts

나를 위해 이것은없이없이 작동했습니다 export. 이것이 맞습니까?
frans

4
나를 위해 exportCentOS7에서만 작동하고 CentOS7에서는 작동하지 않습니다.
user2363318

1
Centos7에서 나는 또한 수출을 사용하지 않아야했다
Banjocat

2
export HTTP_PROXY=...Bashism은 비 Bash 쉘 (예 : / bin / sh와 같은 것)에 대해 두 줄 HTTP_PROXY=...을 사용한 다음 export HTTP_PROXY 전혀 필요하지 않습니다 export.
Cameron Kerr

42

새로운 Mac 용 Docker (또는 Windows 용 Docker)를 사용하는 경우 Docker 트레이 아이콘을 마우스 오른쪽 버튼으로 클릭하고 환경 설정 (Windows : 설정)을 선택한 다음 고급으로 이동하여 프록시 아래에서 프록시 설정을 지정하십시오. 적용 및 다시 시작을 클릭 하고 Docker가 다시 시작될 때까지 기다리 십시오 .


누군가가 나와 같은 macOS 에서 로컬 바운드 프록시 (예 : 127.0.0.1:8787 )를 사용하는 경우 보다 자세한 설정 가이드는 다음과 같습니다 . 로컬 바운드 프록시가 작동하지 않는 이유
Rockallite

Windows : 설정을 통해 프록시를 설정했지만 이러한 프록시가 내 컨테이너로 전파되지 않습니다. stackoverflow.com/questions/48272933/…
amique

나를 위해 나는 단지 DNS 서버에 넣어야했고 그때 작동했습니다. 감사.
richin

32

우분투에서는 클라이언트 프로세스가 아닌 Docker 데몬에 http_proxy를 설정해야합니다. 이 작업은 다음과 같습니다 /etc/default/docker( 여기 참조 ).


그룹에 액세스 할 수있는 권한이 없습니다. 링크에서.
Azizbro

우분투 18.04 이상에서는 작동하지 않는다고 생각합니다.
zslim

27

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

소스는이 블로그 게시물입니다 .


2
HTTP_PROXY 만 필요합니다 (Fedora 20에서 테스트).
sheldonh

수세 12에 딱!
Dean Meehan

14

로컬 바인딩 프록시가 작동하지 않는 이유

문제

수신 대기와 같은 로컬 바운드 프록시를 실행하는 경우 Mac 용 Docker127.0.0.1:8989 에서 작동하지 않습니다 . 로부터 도커 문서 :

컨테이너에서 호스트의 서비스로 연결하고 싶습니다.

Mac의 IP 주소가 변경되었습니다 (또는 네트워크에 액세스 할 수없는 경우). 현재 권장 사항은 사용하지 않는 IP를 lo0Mac 의 인터페이스에 연결하는 것입니다 . 예를 들어 sudo ifconfig lo0 alias 10.200.10.1/24, 서비스가이 주소에서 수신 대기 중인지 0.0.0.0(예 : 아닌 127.0.0.1) 확인하십시오. 그런 다음 컨테이너는이 주소에 연결할 수 있습니다.

Docker 서버 측에서도 마찬가지입니다. (Docker의 서버 측과 클라이언트 측을 이해하려면을 실행하십시오 docker version.) 그리고 서버 측은 고유 한 가상화 계층에서 실행됩니다 localhost. 따라서 localhost호스트 OS 의 프록시 서버에 연결되지 않습니다 .

해결책

따라서 나와 같은 로컬 바운드 프록시를 사용하는 경우 기본적으로 Docker for Mac에서 작동하도록하려면 다음 작업을 수행해야합니다.

  1. 프록시 서버를 0.0.0.0대신 청취하십시오 127.0.0.1. 주의 : 악의적 인 액세스를 방지하려면 적절한 방화벽 구성이 필요합니다.

  2. lo0인터페이스에 루프백 별명을 추가하십시오 ( 예 10.200.10.1/24:

    sudo ifconfig lo0 alias 10.200.10.1/24
    
  3. 에 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
  ...

참고 :로 설정 한 루프백 별명ifconfig은 재부팅 후에도 유지되지 않습니다. 그것을 지속시키는 것은 또 다른 주제입니다. 이 블로그 게시물 을 일본어로확인하십시오(Google 번역이 도움이 될 수 있음).


덕분에 회사 프록시를 통해 회사 네트워크와 외부 네트워크 모두에 액세스하려고 할 때 작년 한 해 동안 Mac에서 SquidMan을 얻는 솔루션을 찾으려고 노력했습니다. 시작시 구성되도록 시작에 연결 하여이 문제를 해결했습니다. developer.apple.com/library/content/documentation/MacOSX/…
Proctor

고마워요 마침내 당신의 게시물을 찾았습니다! 효과가있다. cntlm을 사용하는 경우 구성에 바인딩 0.0.0.0을 추가하는 것을 잊지 마십시오. 예 : 듣기 0.0.0.0 : 8989
Felix

cntlm도 사용하고 있으며 게이트웨이 모드로 변경
Lee Gary

10

이것은 나를 위해 일한 수정 사항입니다 : Ubuntu, Docker 버전 : 1.6.2

파일 /etc/default/docker에서 다음 줄을 추가하십시오.

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

Docker를 다시 시작하십시오.

sudo service docker restart

Ubuntu 14.04 및 Mint 17.3의 Docker v1.12.1 작업
wmarbut

1
14.04.4 + 도커 버전 17.03.1-CE, 빌드 c6d412e에 대한 작품
okwap

8

Docker가 프록시와 작동하도록 구성하려면 HTTPS_PROXY / HTTP_PROXY 환경 변수를 Docker sysconfig 파일 ( /etc/sysconfig/docker) 에 추가해야합니다 .

사용하는지 init.d또는 서비스 툴인지에 따라 "export"문을 추가해야합니다 ( Debian Bug 보고서 로그-# 767441로 인해. / etc / default / docker의 예제는 지원되는 구문과 관련하여 잘못된 것입니다 ) :

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 과 같은 중간 프록시를 사용해야 합니다. 이 블로그 게시물에 자세히 설명되어 있습니다.


5

새로운 버전의 Docker 인 docker-engine시스템 기반 배포에서 다른 사람들이 언급 한 것처럼 /lib/systemd/system/docker.service에 환경 변수 행을 추가해야합니다 .

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

이것은 RHEL7에서 필요했습니다.
dbalakirev

[Service] 섹션에 행을 추가하십시오.
volkit

5

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

내가 아직 언급 할 수 없기 때문에 :

: CentOS는 7 나는 그것이 여기에 설명 된 것처럼 "docker.service"내 EnvironmentFile을 활성화하는 데 필요한 systemd와 제어 및 구성 도커 .

편집 : Nilesh가 명시한대로 솔루션을 추가하고 있습니다. "/etc/systemd/system/docker.service"를 열어야하고 섹션 내에 추가해야했습니다.

[서비스]

EnvironmentFile =-/ etc / sysconfig / docker

그런 다음에 만 "etc / sysconfig / docker"파일이 내 시스템에로드되었습니다.


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 데몬이 인터넷에 액세스 할 수있게하기 위해 (boot2docker와 함께 Kitematic을 사용합니다) 다음을 추가했습니다 /var/lib/boot2docker/profile.

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

그런 다음로 Docker를 다시 시작했습니다 sudo /etc/init.d/docker restart.


3

socks5 프록시를 사용하는 경우 "all_proxy"를 설정 한 Docker 17.03.1-ce의 테스트는 다음과 같습니다.

# 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

3

프록시 설정을 구성하기위한 Windows 용 완벽한 솔루션.

< user>:< password>@< proxy-host>:< proxy-port>

Docker 아이콘에서 설정을 마우스 오른쪽 버튼으로 클릭 한 다음 프록시를 클릭하여 직접 구성 할 수 있습니다.

프록시 주소, 포트, 사용자 이름 및 비밀번호를 구성 할 수 있습니다.

이 형식으로 :

< user>:< password>@< proxy-host>:< proxy-port>

예:

"geronimous:mypassword@192.168.44.55:8080"

이것 외에는 아무것도 없습니다.


2

프록시 환경 변수를 설정하는 것만으로는 버전 1.0.1에서 도움이되지 않았습니다 /etc/default/docker.io. "http_proxy"변수에 대한 올바른 값으로 파일 을 업데이트해야했습니다 .


2

우분투에 있다면이 명령을 실행하여 프록시를 추가하십시오.

sudo nano /etc/default/docker

그리고 지정하는 줄의 주석을 해제하십시오

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

적절한 프록시 서버 및 사용자 이름으로 바꾸십시오.

그런 다음 다음을 사용하여 Docker를 다시 시작하십시오.

service docker restart

이제 프록시 뒤에서 Docker 명령을 실행할 수 있습니다.

docker search ubuntu

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

나는 방화벽 뒤에서도 같은 문제에 직면했다. 아래 단계를 수행하십시오.

$ sudo vim /etc/systemd/system/docker.service.d/http_proxy.conf
[Service]
Environment="HTTP_PROXY=http://username:password@IP:port/"

https_prxoy.conf 파일을 사용하거나 제거하지 마십시오.

Docker 컨테이너를 다시로드하고 다시 시작하십시오.

$ sudo systemctl daemon-reload
$ sudo systemctl restart docker
$ docker pull hello-world
Using default tag: latest
latest: Pulling from library/hello-world
1b930d010525: Pull complete
Digest: sha256:2557*********************************8
Status: Downloaded newer image for hello-world:latest

1

Ubuntu를 사용중인 경우 다음 명령을 실행해야합니다.

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

Docker를 다음과 같이 다시로드하십시오.

service docker.io restart

아니면 /etc/docker.io나노 로 가십시오 ...


1

Docker 1.9.1이 설치된 Ubuntu 14.04 (Trusty Tahr)에서 방금 주석 처리를 취소 http_proxy하고 값을 업데이트 한 다음 Docker 서비스를 다시 시작했습니다.

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

그리고

service docker restart

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/ 덕분에


0

내 네트워크에서 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"

그리고 지금 작동합니다.


0

이 시도:

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

0

이것은 정확히 질문에 대한 대답은 아니지만 특히 서비스 파일을 처리하지 않으려는 경우 도움이 될 수 있습니다.

이미지를 호스팅하는 사람이라면 서버에서 다음과 같은 것을 사용하여 이미지를 tar 아카이브로 변환하는 방법이 있습니다.

docker save <image-name> --output <archive-name>.tar

보관 파일을 다운로드하여 이미지로 다시 변환하십시오.

docker load <archive-name>.tar
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.