centos搭建docker registry镜像仓库

centos搭建docker registry镜像仓库

简介

Docker Registry是一个存储和分发Docker镜像的服务。它允许用户上传、下载和管理 Docker 镜像,为容器化应用的部署提供了便利。

拉取镜像

sh 复制代码
docker image pull registry

证书配置

创建镜像仓库的镜像数据目录和证书目录,便于挂载

sh 复制代码
mkdir /data/registry/data
mkdir /data/registry/certs

生成镜像仓库证书

sh 复制代码
cd /data/registry/certs
openssl req -newkey rsa:4096 -nodes -sha256 -keyout ca.key -x509 -days 365 -out ca.crt -subj \
"/C=CN/ST=GX/L=Bei Jing/O=xxx Technology Co., Ltd./CN=xxx Root Certificate"
openssl req -newkey rsa:4096 -nodes -sha256 -keyout registry.key -out registry.csr -subj \
"/C=CN/ST=GX/L=Bei Jing/O=xxxx Technology Co., Ltd./CN=registry.xxx.com"
openssl x509 -req -days 365 -in registry.csr -CA ca.crt -CAkey ca.key -CAcreateserial -out registry.crt

ssl配置,将自签名证书加入系统证书中心,使操作系统信任

sh 复制代码
## 对于ubuntu系统则是/etc/ssl/certs/ca-certificates.crt
cat /data/registry/certs/ca.crt >> /etc/pki/tls/certs/ca-bundle.crt
systemctl restart docker

仓库运行

sh 复制代码
docker run -d -p 5000:5000 --restart=always --name registry \
-v /data/registry/data:/var/lib/registry \
-v /data/registry/certs:/certs \
-e REGISTRY_HTTP_TLS_CERTIFICATE=/certs/registry.crt \
-e REGISTRY_HTTP_TLS_KEY=/certs/registry.key \
registry:2

客户端访问

使用registry.xxx.com:5000访问,配置镜像仓库的域名解析

sh 复制代码
echo 'x.x.x.x registry.xxx.com' >> /etc/hosts/hosts

镜像迁移

镜像从旧仓库导出

sh 复制代码
docker tag registry:2 registry.xxx.com:5000/public/registry:2
docker save -o registry.tar registry.xxx.com:5000/public/registry:2

镜像导入到新镜像仓库

sh 复制代码
docker load -i registry.tar

镜像推送到新镜像仓库

sh 复制代码
docker push registry.xxx.com:5000/public/registry:2

也可以直接把整个镜像仓库数据文件挂载到新仓库

sh 复制代码
-v /data/registry/data:/var/lib/registry

参考

docker registry官方文档

相关推荐
liuyunluoxiao7 分钟前
进程间通信--共享内存【Linux操作系统】
linux
qq_4541757924 分钟前
gcc/g++常用参数
linux·运维·服务器
wb1891 小时前
Linux远程连接服务
linux·运维·服务器·笔记
Jerry&Louis2 小时前
【Ubuntu】Waydroid-Linux安卓模拟器安装
linux·ubuntu
yangpan0112 小时前
ubuntu 24.04安装ros1 noetic
linux·运维·ubuntu
星卯教育tony2 小时前
ubuntu 20.04 更改国内镜像源-阿里源 确保可用
linux·运维·ubuntu
卡戎-caryon2 小时前
【C++】15.并发支持库
java·linux·开发语言·c++·多线程
weixin_434255613 小时前
命令行快速上传文件到SFTP服务器(附参考示例)
linux·运维·服务器
麟城Lincoln3 小时前
【Linux笔记】nfs网络文件系统与autofs(nfsdata、autofs、autofs.conf、auto.master)
linux·网络·笔记·nfs·autofs
***似水流年***4 小时前
Linux任务管理与守护进程
linux·运维·服务器