13.docker私服registry搭建

容器注册

Docker Hub是最大、使用最广泛的docker容器注册托管中心。

  • registry用于保存docker镜像,包括镜像的层次结构和元数据。
  • 启动容器时,docker daemon会试图从本地获取相关的镜像;本地镜像不存在时,其将从registry中下载该镜像并保存到本地;
  • 拉取镜像时,如果不知道registry仓库地址,默认从Docker Hub搜索拉取镜像

我们可以利用docker自己搭建私有registry。一般私有registry不像docker hub功能齐全,而是只提供了基础功能,比较适合小团队。

启动私有docker registry

启动docker registry

bash 复制代码
docker container run -d -p 5000:5000 --name registry registry

docker container ls
# CONTAINER ID   IMAGE         COMMAND                  CREATED          STATUS                  PORTS                    NAMES
# d88855125dd4   registry      "/entrypoint.sh /etc..."   1 second ago     Up Less than a second   0.0.0.0:5000->5000/tcp   registry

重新给镜像打标签,并且推送到私有registry

bash 复制代码
docker pull hello-world

docker run --name hello hello-world 

docker tag hello-world 127.0.0.1:5000/hello-world

docker image ls

docker push 127.0.0.1:5000/hello-world

docker container rm hello

docker image remove hello-world

docker image remove 127.0.0.1:5000/hello-world

docker image ls

从本地删除对应镜像缓存

从私有registry尝试拉取镜像

bash 复制代码
docker pull 127.0.0.1:5000/hello-world

docker image ls

将私有registry的数据持久化到宿主机

bash 复制代码
docker container kill registry

docker container rm registry

docker container run -d -p 5000:5000 --name registry -v $(pwd)/registry-date:/var/lib/registry registry

ls -al

docker push 127.0.0.1:5000/hello-world

ls -al

tree registry-date

使用Swarm将registry部署到线上

使用swarm部署registry服务,利用routing mesh特性

我们先部署5个manager节点,

bash 复制代码
docker node ls

docker service create --name registry --publish 5000:5000 registry

docker service ps registry
# ID             NAME         IMAGE             NODE       DESIRED STATE   CURRENT STATE            ERROR     PORTS
# jfwgt7gmwu62   registry.1   registry:latest   manager1   Running         Running 13 seconds ago  

利用routing mesh特性,我们可以在任意节点上从私有registry拉取镜像

bash 复制代码
curl localhost:5000/v2/_catalog
# {"repositories":[]}

docker pull hello-world

docker tag hello-world 127.0.0.1:5000/hello-world

docker push 127.0.0.1:5000/hello-world

curl localhost:5000/v2/_catalog
# {"repositories":["hello-world"]}


docker pull nginx

docker tag nginx 127.0.0.1:5000/nginx

docker push 127.0.0.1:5000/nginx

curl localhost:5000/v2/_catalog

docker service create --name nginx -p 80:80 --replicas 5 --detach=false 127.0.0.1:5000/nginx

docker service ps nginx

可以看到5个节点都成功拉取到了私服的镜像

相关推荐
凯子坚持 c5 分钟前
Docker LXC深度解析:从基础概念到实战演练
java·开发语言
先做个垃圾出来………6 分钟前
Docker容器部署方法
运维·docker·容器
m0_7482336412 分钟前
【C++篇】C++11入门:踏入C++新世界的大门
java·c++·算法
SWUT胖虎24 分钟前
ArkTS 中 @State 底层原理详解
java·list·harmonyos·鸿蒙
SimonKing27 分钟前
【开发者必备】Spring Boot 2.7.x:WebMvcConfigurer配置手册来了(四)!
java·后端·程序员
BAGAE31 分钟前
HTTPS 加密原理介绍
java·c++·websocket·http·均值算法·启发式算法·最小二乘法
这周也會开心34 分钟前
SpringBoot的搭建方式
java·spring boot·后端
sun༒1 小时前
递归经典例题
java·算法
小年糕是糕手1 小时前
【C语言】函数栈帧的创建和销毁
java·c语言·开发语言·数据结构·c++·链表
努力努力再努力wz1 小时前
【Linux进阶系列】:信号(下)
java·linux·运维·服务器·开发语言·数据结构·c++