Docker搭建本地私有仓库

目录

[1.下载运行registry 镜像](#1.下载运行registry 镜像)

2.添加私有镜像仓库地址

3.为镜像添加标签

4.上传到私有仓库

5.查看私有仓库的所有镜像

6.测试私有仓库下载

1.下载运行registry 镜像

复制代码
docker pull registry
docker run -d -v /data/registry:/var/lib/registry -p 5000:5000 --restart=always --name registry registry:latest

-----------------------------------------------------------------------------------------
-itd:在容器中打开一个伪终端进行交互操作,并在后台运行
-v:把宿主机的/data/registry目录绑定到容器/var/lib/registry目录(这个目录是registry容器中存放镜像文件的目录),来实现数据的持久化;
-p:映射端口;访问宿主机的5000端口就访问到registry容器的服务了
--restart=always:这是重启的策略,在容器退出时总是重启容器
--name registry:创建容器命名为registry
registry:latest:这个是刚才pull下来的镜像
-----------------------------------------------------------------------------------------
Docker容器的重启策略如下:
no:默认策略,在容器退出时不重启容器
on-failure:在容器非正常退出时(退出状态非0),才会重启容器
on-failure:3 :在容器非正常退出时重启容器,最多重启3次
always:在容器退出时总是重启容器
unless-stopped:在容器退出时总是重启容器,但是不考虑在Docker守护进程启动时就已经停止了的容器


2.添加私有镜像仓库地址

复制代码
#在 daemon.json 文件中添加私有镜像仓库地址
vim /etc/docker/daemon.json
{
  "registry-mirrors": ["https://ustqgeoy.mirror.aliyuncs.com"],
  "insecure-registries": ["http://192.168.9.113:5000"]       #添加私有镜像仓库地址,指定本机ip
}

systemctl restart docker
docker info


3.为镜像添加标签

复制代码
docker images
docker tag nginx:lnmp 192.168.9.113:5000/nginx:lnmp
docker tag openjdk:8-jdk-alpine 192.168.9.113:5000/openjdk:a1
docker images


4.上传到私有仓库

复制代码
docker push 192.168.9.113:5000/nginx:lnmp
docker push 192.168.9.113:5000/openjdk:a1


5.查看私有仓库的所有镜像

复制代码
http://192.168.9.113:5000/v2/_catalog   #查看私有仓库所有镜像
http://192.168.9.113:5000/v2/openjdk(指定镜像名)/tags/list  #指定镜像查看其标签


6.测试私有仓库下载

重新开启一台服务器测试下载私有仓库镜像(先删除原有的 centos 的镜像,再测试私有仓库下载

复制代码
cd /etc/docker
vim daemon.json
{
   "insecure-registries": ["http://192.168.9.113:5000"]    #添加私有仓库地址
}


systemctl restart docker

docker info

docker pull 192.168.9.113:5000/nginx:lnmp  #从私有仓库中拉去镜像
docker pull 192.168.9.113:5000/openjdk:a1
docker images


相关推荐
七夜zippoe14 小时前
CANN Runtime任务描述序列化与持久化源码深度解码
大数据·运维·服务器·cann
金刚猿14 小时前
01_虚拟机中间件部署_root 用户安装 docker 容器,配置非root用户权限
docker·中间件·容器
JH_Kong15 小时前
解决 WSL 中 Docker 权限问题:从踩坑到完整修复
docker·容器
忆~遂愿15 小时前
GE 引擎与算子版本控制:确保前向兼容性与图重写策略的稳定性
大数据·开发语言·docker
Fcy64816 小时前
Linux下 进程(一)(冯诺依曼体系、操作系统、进程基本概念与基本操作)
linux·运维·服务器·进程
袁袁袁袁满16 小时前
Linux怎么查看最新下载的文件
linux·运维·服务器
代码游侠16 小时前
学习笔记——设备树基础
linux·运维·开发语言·单片机·算法
Harvey90316 小时前
通过 Helm 部署 Nginx 应用的完整标准化步骤
linux·运维·nginx·k8s
陈桴浮海17 小时前
Kustomize实战:从0到1实现K8s多环境配置管理与资源部署
云原生·容器·kubernetes
珠海西格电力科技17 小时前
微电网能量平衡理论的实现条件在不同场景下有哪些差异?
运维·服务器·网络·人工智能·云计算·智慧城市