Docker部署私有仓库(registry&Harbor)

网友投稿 280 2022-10-31

Docker部署私有仓库(registry&Harbor)

仓库(Repository)是集中存放镜像的地方。一个容易混淆的概念是注册服务器(registry)。实际上注册服务器是管理仓库的具体服务器,每个服务器上可以有多个仓库,而每个仓库下面有多个镜像。从这方面来说,仓库可以被认为是一个具体的项目或目录。例如对于仓库地址docker.sina.com.cn/centos:centos7来说,docekr.sian.com.cn是注册服务器地址,centos是仓库名,centos7是仓库的tag(标签)。

Docker Hub 官方仓库目前docker官方维护了一个公共仓库,Docker Hub,其中已经包括了超过1500的镜像。大部分需求,都可以通过在Docker Hub中直接下载镜像来实现。

部署私有仓库:

1, 通过官方的registry镜像来部署私有仓库:

项目环境:两台主机(centos7):docker01:172.16.1.30docker02:172.16.1.40**

docker01:(1)基于registry镜像运行一个容器:[root@sqm-docker01 ~]# docker run -d --name registry --restart=always -p 5000:5000 -v /data/registry:/var/lib/registry registry:latest

参数说明: #registry服务默认监听的是5000端口 -v = --volume 数据卷,进行一个挂载:宿主机:容器内

(2)命名私有仓库镜像:##如果不对私有仓库命名的话,默认走的是公共仓库(docker hub),所以需要命名镜像。私有仓库镜像的命名规则:宿主机ip地址:端口号/xxxx(需要更改的名称)以nignx镜像为例,下载nginx镜像:[root@sqm-docker01 ~]# docker pull nginx

[root@sqm-docker01 ~]# docker tag nginx:latest 172.16.1.30:5000/nginx:latest

注意:当你对源镜像(nginx:latest)进行命名后,命名后的镜像名称也视为一个标签,因为id号是相同的。如果当源镜像(nginx:latest)删除,命名后的镜像依然会存在,因为删除的是一个标签。

(3)修改docker主配置文件:[root@sqm-docker01 ~]# vim /usr/lib/systemd/system/docker.service

重新加载进程并重启docker服务:

[root@sqm-docker01 ~]# systemctl daemon-reload [root@sqm-docker01 ~]# systemctl restart docker

//查看私有仓库中的镜像:

[root@sqm-docker01 ~]# curl 172.16.1.30:5000/v2/_catalog {"repositories":["nginx"]}

//查看仓库中镜像的标签:

[root@sqm-docker01 ~]# curl 172.16.1.30:5000/v2/nginx/tags/list {"name":"nginx","tags":["latest"]}

//如果需要删除私有仓库中的镜像,因为我有尝试用官方的第三方工具(deletedockerregistryimage)来进行删除镜像,但最终并没有把仓库中的镜像删除。所以我采取在运行registry时挂载在本地的目录[/data/registry]中,找到指定的镜像存放的目录来进行删除。

[root@sqm-docker01 ~]# cd /data/registry/docker/registry/v2/ [root@sqm-docker01 v2]# ls blobs repositories [root@sqm-docker01 v2]# cd repositories/ [root@sqm-docker01 repositories]# ls nginx [root@sqm-docker01 repositories]# rm -rf nginx/

删除后再次查看私有仓库中的镜像是否还存在: [root@sqm-docker01 ~]# curl http://172.16.1.30:5000/v2/_catalog {"repositories":[]}

可以看到仓库中的镜像已被成功删除。

重启docker服务:

[root@sqm-docker02 ~]# systemctl daemon-reload [root@sqm-docker02 ~]# systemctl restart docker

(2)从私有仓库中拉取镜像:

[root@sqm-docker02 ~]# docker pull 172.16.1.30:5000/nginx #使用pull命令进行拉取

(3)部署nginx服务:

[root@sqm-docker02 ~]# mkdir html [root@sqm-docker02 ~]# echo "welcome to nginx web" > html/index.html

[root@sqm-docker02 ~]# docker run -itd --name nginx -p 80:80 -v /root/html:/usr/share/nginx/html 172.16.1.30:5000/nginx

2,部署Harbor(哈勃)私有仓库:

registry是官方的一个私有仓库,而harbor是第三方的一个私有仓库。

[root@sqm-docker01 ~]# curl -L -s-uname -m-o /usr/local/bin/docker-compose

[root@sqm-docker01 ~]# chmod +x /usr/local/bin/docker-compose

查看compose版本:

[root@sqm-docker01 ~]# docker-compose -version docker-compose version 1.24.0, build 0aa59064

(2)下载harbor安装包并进行解压:

[root@sqm-docker01 ~]# tar zxf harbor-offline-installer-v1.7.4.tgz -C /usr/local/ [root@sqm-docker01 ~]# cd /usr/local/harbor/

进入网站:用户admin,密码:Harbor12345(在harbor配置文件中可以查看到)URL:[root@sqm-docker01 harbor]# vim harbor.cfg

//重新加载docker:

[root@sqm-docker01 ~]# systemctl daemon-reload [root@sqm-docker01 ~]# systemctl restart docker

//重启compose:注意:因为刚刚已经重启了docker服务,所以我们需要将所有容器给重新启动。[root@sqm-docker01 harbor]# docker ps -a -q | xargs docker start

[root@sqm-docker01 harbor]# docker-compose stop

(5)将需要上传到harbor私有仓库的镜像进行push:#例如将本地的一个nginx镜像命令并且push到仓库:[root@sqm-docker01 harbor]# docker tag nginx:latest 172.16.1.30:80/sunqiuming/nginx:latest

[root@sqm-docker01 ~]# scp /usr/lib/systemd/system/docker.service root@172.16.1.40:/usr/lib/systemd/system/docker.service

重启docker服务:[root@sqm-docker02 ~]# systemctl daemon-reload[root@sqm-docker02 ~]# systemctl restart docker

私有仓库部署完成。。。。。。。

———————— 本文至此结束,感谢阅读 ————————

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:一文详解高级可扩展接口
下一篇:电液伺服机构与CAN总线接口设计
相关文章

 发表评论

暂时没有评论,来抢沙发吧~