前言
上一篇文章讲了Docker Machine实现多主机Docker节点的管理。本文讲解如何实现Docker Registry,其实这个在第一篇Docker入门一文中已经简单介绍,本文仅是对一些细节做个说明。
Why Docker Registry?
有时我们的服务器无法访问互联网,或者你不希望将自己的镜像放到公网当中,那么你就需要Docker Registry,它可以用来存储和管理自己的镜像。
How to install Docker Registry?
其实创建私有的Docker仓库非常简单,只需要运行一个Registry容器即可,该容器存储在Docker HUB中。
docker run -d -p 5000:5000 -v /myregistry:/var/lib/registry registry
-d 是后台启动容器。
-p 将容器的 5000 端口映射到 Host 的 5000 端口。5000 是 registry 服务端口。
-v 将容器 /var/lib/registry目录映射到宿主机的/myregistry,用于存放镜像数据。
How to use Docker Registry?
理论上我们已经搭建好了自己的私有镜像仓库,但这时候还有一些问题需要我们解决。
在pull或者push镜像时报拒绝连接的错误。
这是由于Registry为了安全性考虑,默认是需要证书支持的,证书这块我倒没有研究过,可以通过一个简单的办法解决。创建或者修改/etc/docker/daemon.json
文件,并在其中写入
{
"insecure-registries": ["<ip>:5000"]
}
其中为安装了Registry的机器ip地址。需要注意的是在安装registry的节点和客户端需要访问私有Registry的节点都需要执行此步操作。
修改文之后执行以下命令重启节点docker。
systemctl daemon-reload
systemctl restart docker
我是在ubuntu16环境进行的上述操作,其他系统可以参考相应命令。
通过 docker tag重命名镜像,使之与registry匹配。
docker tag wsf <ip>:5000/wsf:v1
给wsf镜像重命名为:5000/wsf:v1,v1为版本号,前面必须要加上域名或IP地址(运行上面registry容器的地址)和端口号。
其实Docker HUB与我们要建立的私有Registry没有本质的区别。
docker run ubuntu
语句从官方hub中寻找镜像,它是
docker run docker.io/library/ubuntu
的简写。
docker.io即是上面的ip地址,端口号为80省略。
上传镜像
docker push <ip>:5000/wsf:v1
下载镜像
docker pull <ip>:5000/wsf:v1
上传和下载镜像都可以在任意能访问Registry的节点上进行。前提是此节点必须进行上述的修改daemon.json操作。
查看Registry中所有镜像信息
curl http://<ip>:5000/v2/_catalog
此语句会返回一个json,包含当前Registry中存储的镜像信息。
总结
本文简单为大家介绍了Docker Registry的相关细节,有了这个东西就能更好的实现docker的多主机管理和我们自定义镜像的管理。