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个节点都成功拉取到了私服的镜像

相关推荐
间彧2 分钟前
复用线程:原理详解与实战应用
java
小Wang1 小时前
npm私有库创建(docker+verdaccio)
前端·docker·npm
咖啡Beans2 小时前
使用OpenFeign实现微服务间通信
java·spring cloud
我不是混子2 小时前
说说单例模式
java
间彧4 小时前
SimpleDateFormat既然不推荐使用,为什么java 8+中不删除此类
java
间彧4 小时前
DateTimeFormatter相比SimpleDateFormat在性能上有何差异?
java
间彧4 小时前
为什么说SimpleDateFormat是经典的线程不安全类
java
MacroZheng4 小时前
横空出世!MyBatis-Plus 同款 ES ORM 框架,用起来够优雅!
java·后端·elasticsearch
用户0332126663675 小时前
Java 查找并替换 Excel 中的数据:详细教程
java