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官方文档

相关推荐
添砖java‘’9 小时前
vim高效编辑:从入门到精通
linux·编辑器·操作系统·vim
tryCbest10 小时前
CentOS部署Docker容器
linux·docker·centos
菠萝炒饭pineapple-boss11 小时前
单机让多docker拥有多ip出口
docker
qyhua12 小时前
【Linux运维实战】彻底修复 CVE-2011-5094 漏洞
linux·运维·安全
坠金12 小时前
linux/centos迁移conda文件夹
linux·centos·conda
纳于大麓13 小时前
Kotlin基础语法
linux·windows·kotlin
九皇叔叔13 小时前
Linux Shell 正则表达式中的 POSIX 字符集:用法与实战
linux·运维·正则表达式
007php00713 小时前
百度面试题解析:微服务架构、Dubbo、Redis及其一致性问题(一)
redis·百度·docker·微服务·容器·职场和发展·架构
東雪蓮☆13 小时前
K8s 平滑升级
linux·运维·云原生·kubernetes
---学无止境---14 小时前
Linux中进程创建和缓存对象初始化fork_init、proc_caches_init和buffer_init
linux