Docker 本地注册表:推送失败

Docker local registry : push fails

我正在尝试设置本地 docker 注册表,但在尝试将图像推送到它时遇到了麻烦。我也开了一个github问题:https://github.com/docker/docker/issues/12405

环境

OS: 美分OS 6.6

内核:2.6.32-504.12.2.el6.x86_64

Docker版本:

$ sudo docker version
Client version: 1.5.0
Client API version: 1.17
Go version (client): go1.4.1

我使用公司代理 (http://domain\username:password@proxy:port)。

问题

我正在使用此命令启动 Docker 守护程序:

sudo docker -d --insecure-registry 127.0.0.1:49500&

我已经从 docker-registry github 下载了 config_sample.yml 文件,将其重命名为 registry_config.yml,并且刚刚修改了 "storage_path"本地风味(为了指向我要挂载卷的选定目录):

local: &local
<<: *common
storage: local
storage_path: /image

要启动注册表(版本 0.9.1),我在终端中打开另一个选项卡并使用该命令:

sudo docker run -t -i -p 127.0.0.1:49500:5000 -v $HOME/localRegistry/image:/image -e DOCKER_REGISTRY_CONFIG=$HOME/localRegistry/registry_config.yml --name registry registry /bin/bash

回到第一个终端选项卡,然后我尝试将 运行dom 图像推送到本地注册表,这是我遇到一些错误的地方:

$sudo docker push 127.0.0.1:49500/centos:7
INFO[1215] POST /v1.17/images/127.0.0.1:49500/centos/push?tag=7
INFO[1215] +job push(127.0.0.1:49500/centos)
INFO[1215] +job resolve_repository(127.0.0.1:49500/centos)
INFO[1215] -job resolve_repository(127.0.0.1:49500/centos) = OK (0)
invalid registry endpoint "http://127.0.0.1:49500/v0/". HTTPS attempt: unable to ping registry endpoint https://127.0.0.1:49500/v0/
v2 ping attempt failed with error: Get https://127.0.0.1:49500/v2/: read tcp 127.0.0.1:49500: connection reset by peer
v1 ping attempt failed with error: Get https://127.0.0.1:49500/v1/_ping: read tcp 127.0.0.1:49500: connection reset by peer. HTTP attempt: unable to ping registry endpoint http://127.0.0.1:49500/v0/
v2 ping attempt failed with error: Get http://127.0.0.1:49500/v2/: read tcp 127.0.0.1:49500: connection reset by peer
v1 ping attempt failed with error: Get http://127.0.0.1:49500/v1/_ping: read tcp 127.0.0.1:49500: connection reset by peer
INFO[1215] -job push(127.0.0.1:49500/centos) = ERR (1)
ERRO[1215] Handler for POST /images/{name:.*}/push returned error: v1 ping attempt failed with error: Get http://127.0.0.1:49500/v1/_ping: read tcp 127.0.0.1:49500: connection reset by peer
ERRO[1215] HTTP Error: statusCode=500 v1 ping attempt failed with error: Get http://127.0.0.1:49500/v1/_ping: read tcp 127.0.0.1:49500: connection reset by peer
FATA[0000] Error: v1 ping attempt failed with error: Get http://127.0.0.1:49500/v1/_ping: read tcp 127.0.0.1:49500: connection reset by peer

问我是否需要更具体的细节。感谢您的关注:)

更新

我没注意到,但自从我昨天从 Docker 1.4.1 升级到 1.5.0 后,似乎 docker 无法通过代理到达集线器(sudo docker 搜索失败)。我通过导出 HTTP_PROXY 和 HTTPS_PROXY 环境变量,并使用 sudo -E 启动守护进程来解决这个问题。

然后,正如 SGer 指出的那样,我并没有将我的配置文件放入注册表容器中。因此,注册表无法访问配置。我通过将配置文件移动到它自己的目录中,并在 运行 注册表容器时将该目录作为卷安装来更改它。新的 运行 命令:

sudo docker run -t -i -p 127.0.0.1:49500:5000 -v $HOME/localRegistry/image:/image -v $HOME/localRegistry/configDir:/configDir -e DOCKER_REGISTRY_CONFIG=configDir/config.yml --name registry registry /bin/bash

在这2个修改之后,我再次测试,运行 docker 守护进程与-D选项。这是输出(分为 3 部分):

https://gist.github.com/ekeryelleven/9714312c45b7ff21ce2a

我启动了注册表容器(从另一个终端选项卡):https://gist.github.com/ekeryelleven/b9bfa50bfe3221798659

然后,我推送了:https://gist.github.com/ekeryelleven/80f8f1d1dad00b0fbea9

更新 2

有人告诉我它可能链接到 https://github.com/docker/docker/issues/9315

我尝试重现:

$ wget -O- --post-data='' 'http://127.0.0.1:49500/images'
--2015-04-16 11:01:42--  http://127.0.0.1:49500/images
Resolving <proxy>... <ip>
Connecting to <proxy>|<ip>|:<port>... connected.
Proxy request sent, awaiting response... 504 Gateway Timeout
2015-04-16 11:01:42 ERROR 504: Gateway Timeout.

所以我认为当我尝试访问本地注册表时代理可能搞砸了,所以我再次 运行 我的第一次测试没有为 docker 守护程序设置任何代理配置(没有 HTTP_PROXY 和 HTTPS_PROXY 变量,没有 sudo -E)。输出(3 部分):

http://pastebin.com/raw.php?i=XaJaSsWk

启动注册表容器:http://pastebin.com/raw.php?i=1tux468H

推送:http://pastebin.com/raw.php?i=LsvNfdQf

不是真正的答案,但我升级到 Docker 1.6 和 Registry 2.0,问题消失了。