本文最后更新于 319 天前,其中的信息可能已经过时,如有错误请发送邮件到wuxianglongblog@163.com
docker的轻量级私有仓库之docker-registry
一.私有仓库概述
1.为什么要有私有仓库
在讲解使用私有仓库之前,我们需要分析为什么要有私有仓库,可参考以下两点:
(1)速度慢,官方的镜像仓库在国外,访问速度不言而喻;
(2)安全性底,如果企业开发的核心代码上传到官方的镜像仓库,这意味着大家都能看到企业内部的代码;
综上所述,我们急需一款私有仓库的解决方案。
2.主流的私有仓库有哪些
对于docker的私有仓库有很多,但相对主流的我们课程里只会涉及两款,即docker-registry和harbor。
docker-registry:
是一个轻量级的镜像仓库,基本上不太占用内存,很适合学习环境中使用。
harbor:
对内存有要求,宿主机最少得拥有2G内存,对于个别用户,可能它相对重量级了,但对于企业它是主流。
二.部署docker-registry
1.下载镜像
[root@docker201.oldboyedu.com ~]# docker pull registry
2.启动registry私有镜像仓库
docker run -d -p 5000:5000 --restart=always --name oldboyedu-image-registry -v /var/lib/registry registry
3.查看镜像地址
如下图所示,访问:"http://docker201.oldboyedu.com:5000/v2/_catalog"
三.将镜像上传到私有镜像仓库
1.为镜像打tag
[root@docker201.oldboyedu.com ~]# docker tag mysql:8.0 docker201.oldboyedu.com:5000/oldboyedu/mysql:8.0
温馨提示:
如下图所示,我们要为镜像打上相应的tag,以便于方便咱们将其上传到指定的镜像仓库。默认是官方的镜像仓库。
2.添加信任仓库,默认协议是https协议,而我们刚刚搭建的私有仓库是http协议。
[root@docker201.oldboyedu.com ~]# vim /etc/docker/daemon.json
[root@docker201.oldboyedu.com ~]#
[root@docker201.oldboyedu.com ~]# cat /etc/docker/daemon.json
{
"registry-mirrors": ["https://tuv7rqqq.mirror.aliyuncs.com"],
"insecure-registries": ["docker201.oldboyedu.com:5000"]
}
[root@docker201.oldboyedu.com ~]#
[root@docker201.oldboyedu.com ~]# systemctl restart docker
温馨提示:
记得重启docker服务使之生效。
3.上传镜像
[root@docker201.oldboyedu.com ~]# docker image push docker201.oldboyedu.com:5000/oldboyedu/mysql:8.0
温馨提示:
镜像推送成功后,请查看registry中是否有记录哈。
四.使用镜像
1.下载镜像
[root@docker202.yinzhengjie.com ~]# docker image pull docker201.oldboyedu.com:5000/oldboyedu/mysql:8.0
温馨提示:
如下图所示,在下载镜像的时候,请确保"/etc/docker/daemon.json"和"/etc/hosts"中的数据。
2.删除本地镜像
[root@docker202.yinzhengjie.com ~]# docker image rm docker201.oldboyedu.com:5000/oldboyedu/mysql:8.0
温馨提示:
是否发现下载镜像和删除镜像都一样了,本来就是,因为我们依旧是使用的镜像管理命令。
3.其它操作
由于操作基本上一样,我就不一一展示了。
五.删除registry私有仓库中的镜像文件
1.进入到registry的容器中
[root@docker201.oldboyedu.com ~]# docker container exec -it registry sh
2.删除元数据信息
/var/lib/registry/docker/registry/v2 # rm -rf repositories/oldboyedu/mysql/
3.手动回收无用文件
/ # registry garbage-collect /etc/docker/registry/config.yml
温馨提示:
回收无用文件后,不难发现镜像的存储空间也得到了部分释放哟~
六.可能会遇到的错误
1.http: server gave HTTP response to HTTPS client
报错原因:
如下图所示,默认协议是https,而我们的仓库响应的http协议。、
解决方案:
[root@docker201.oldboyedu.com ~]# vim /etc/docker/daemon.json
[root@docker201.oldboyedu.com ~]#
[root@docker201.oldboyedu.com ~]# cat /etc/docker/daemon.json
{
"registry-mirrors": ["https://tuv7rqqq.mirror.aliyuncs.com"],
"insecure-registries": ["docker201.oldboyedu.com:5000"]
}
[root@docker201.oldboyedu.com ~]#