设置一个本地的私人仓库来进行镜像的管理。
仓库实际上就是一个容器,在Docker Hub中提供了创建私人仓库的镜像Resposity(镜像仓库):Registry
# 以Registry:2镜像为例,构建一个私人仓库。 docker run -d -p 5000:5000 --restart=always --name registry registry:2 --restart=always是指在Docker服务重启或者registry容器退出时会重新启动。-p是指将宿主机的5000端口映射到容器的5000端口,这样就可以通过宿主机ip:5000访问到容器的5000端口了。(registry容器默认会监听5000端口)。-d参数是指在后台运行。-v指定私人仓库的存储位置,添加-v /mnt/registry:/var/lib/registry可以将私人仓库的存储位置设置为宿主机的/mnt/registry。更多更详细的配置可以参考: https://docs.docker.com/registry/deploying/#start-the-registry-automatically 。
如果想要将镜像推送到私人仓库而不是Docker Hub,首先必须使用docker tag命令,使用主机名和端口来标记一个镜像。
# 为ubuntu:latest镜像加上一个localhost:5000/my-ubuntu:latest的标签 docker tag ubuntu:latest localhost:5000/my-ubuntu使用docker push命令可以将镜像推送到仓库,默认情况下会将镜像推送到官方仓库Docker Hub中去,但是如果推送一个“用主机名和端口来标记”的镜像,那么就会推送到私人仓库。
docker push localhost:5000/my-ubuntudocker pull可以从仓库拉取某个镜像,默认情况下,也是从官方仓库拉取。想从私人仓库拉取my-ubuntu:latest镜像,执行以下命令就行了。
docker pull localhost:5000/my-ubuntuDocker提供的Registry镜像没有提供查看镜像和删除镜像的指令,但是有第三方的软件可以提供这些功能,例如:harbor。
harbor提供一个可视化的界面来操作私人仓库,包括查看私人仓库中的镜像以及删除私人仓库中的镜像,除此以外,还有日志等非常有用的功能。
具体的安装与介绍请参照:https://github.com/vmware/harbor/ 。
私人仓库实质上就是一个容器,所以删除私人仓库就是删除私人仓库对应的容器。我们可以使用docker rm -f 强制删除删除它,但是这样删除之后,私人仓库中存储的镜像并不会被删除掉。如果你想在删除私人仓库的同时,也将镜像删除,需要添加-v参数,也就是docker rm -f -v。例如删除本地的私人仓库,可以执行以下语句:
docker rm -vf myregistry
参考:https://www.educoder.net/shixuns/4uyn5ebp/challenges
软件工程小施同学 认证博客专家 学堂在线讲师 每一个伟大,都源于一个勇敢的开始(微博:“软件工程小施同学”,公号”微程序学堂“)