😜即日起,更新云原生相关知识,喜欢的小伙伴可以给我点个三连喔
😜收录至专栏 云原生
😜【云原生Docker系列第四篇】Docker Cgroups资源控制操作
😜【云原生Docker系列第九篇】Docker-Compose 容器集群的快速编排
😜【云原生Docker系列项目实战第一篇】dockerfile+lnmp+workpress
😜【云原生Kubernetes系列第一篇】深入理解容器集群管理系统Kubernetes(k8s)
😜【云原生Kubernetes系列第二篇】Kubernetes(k8s)核心组件
Docker Hub为我们提供了很多官方镜像和个人上传的镜像,我们可以下载机构或个人提供的镜像,也可以上传我们自己的本地镜像,但缺点是:
为了解决以上问题,Docker 官方提供了一个叫做 registry 的镜像用于搭建本地私有仓库使用。在内部网络措建的Docker。私有仓库可以使内网人员下载、上传都非常快速, 不受外网带宽等因素的影响,同时不在内网的人员也无法下载我们的镜像,并且私有仓库也支持配置仓库认证功能。接下来详细讲解registry私有仓库的搭建过程。
docker pull registry #获取镜像
vim /etc/docker/daemon.json
{
"insecure-registries":["192.168.109.136:5000"], #注意用逗号结尾,没有逗号会启动失败
"registry-mirrors": ["https://678ejrsl.mirror.aliyuncs.com"]
}
systemctl restart docker.scrvice #重启docker服务
docker run -d -v /data/registry:/var/lib/registry -p 5000:5000 --restart=always --name registry registry:latest
-itd:在容器中打开一个伪终端进行交互操作,并在后台运行
-v:把宿主机的/data/registry目录绑定到容器/var/lib/rcgistry日录(这个目录是registry容器中存放镜像文件的日录),来实现数据的持久化:
-p:映射端口:访问宿主机的5000端口就访问到reqisLry容器的服务了
--restart=always:这是重启的策略,在容器退出耐总是重启容器
--name reqistry:创建容器命名为reqistry
reqistry:latest:这个是刚才pull下来的镜像
Docker容器的重启策略如下:
no:默认策略,在容器退出时不重启容器
on-failure:在容器非正常退出时(退出状态非0),才会重启容器
on-failure:3:在容器非正常退出时重启容器,最多重启3次
always:在容器退出时总是重启容器
unless-sLopped:在容器退出时总是重启容器,但是不考虑在Docker守护进程启动时就已经停止了的容器
#拉取镜像
docker pull nginx
#打标签
docker tag nginx:latest 192.168.109.136:5000/nginx:v1
docker push 192.168.109.136:5000/nginx:v1
网页访问192.168.109.136:5000:/v2/_catalog
[root@localhost ~]# curl http://192.168.109.136:5000/v2/nginx/tags/list
{"name":"nginx","tags":["v1"]}
docker rmi -f 0e901e68141f
docker pull 192.168.109.136:5000/nginx:v1