Docker 的仓库是 DockerHub,类似于 GitHub。GitHub 有一个开源的软件叫 GitLab。Docker 也有一个开源软件 Docker registry。
创建私有仓库
在私有仓库主机上下载 registry 镜像。
docker pull registry
1
默认情况下,仓库会将镜像存放在/var/lib/registry 目录下,这里指定本地一个目录挂载到容器内的/var/lib/registry 下,如下:
sudo mkdir -pv /opt/data/registry
docker run -d -p 5000:5000 -v /opt/data/registry:/var/lib/registry registry
1
2
此时就会启动一个 registry 容器,地址为 http://:5000。
测试一下
接下来我们要做的就是把本地的一个镜像 push 到私有仓库中去,首先在本机上 pull 一个比较小的镜像来做测试(此处使用的是 busybox)。
docker pull busybox
1
接下来修改镜像的 tag。
docker tag busybox 127.0.0.1:5000/busybox
1
接下来将打了 tag 的镜像上传到私有仓库中。
docker push 127.0.0.1:5000/busybox
1
可以看到镜像已经 push 到私有仓库中去了。
接下来,我们删除本地镜像,然后从私有仓库 pull 下来该镜像。
docker pull 127.0.0.1/busybox
1
由此可见,Docker 镜像的本地仓库已经搭建成功,并且可以正常使用了。
如何修改默认的镜像仓库
执行 docker pull image_NAME 默认都是去官方来拉取。本地已建 registry,就是每次得以这种格式拉取:docker pull IP:PORT/image_NAME,很不方便。利用下边的方法可以实现首先从本地仓库中查询,如果本地仓库中没有再去官方镜像源拉取。
修改配置文件/etc/default/docker。增加如下内容:
DOCKER_OPTS=”–insecure-registry 127.0.0.1:5000″
1
修改完成后,重启 docker 服务即可。
service docker restart
1
注意:
因为 Docker 从 1.3.X 以后,与 docker registry 交互默认使用的是 https,然而此处搭建的私有仓库只提供 http 服务,所以当与私有仓库交互时会报上面的错误。为了解决这个问题需要在启动 docker server 时增加参数为默认使用 http 访问,修改 docker 启动的配置文件。
作者:xkjcf
来源:CSDN
原文:https://blog.csdn.net/xkjcf/article/details/78683407
版权声明:本文为博主原创文章,转载请附上博文链接!