下载离线镜像
检查Docker环境
bash
docker version
data:image/s3,"s3://crabby-images/ce869/ce86940f554ac513a85da0ff103f7f4c65b9ef26" alt=""
Docker Hub 中registry 最新版本为 2.8.3,详见 registry . https://hub.docker.com/_/registry/tags
下载镜像
bash
docker pull registry:2.8.3
data:image/s3,"s3://crabby-images/903a8/903a8d8915ffc7fc14e7e46734edbb9bdbf007af" alt=""
离线导出,方便在无法联网的设备上安装
bash
docker image save registry:2.8.3 -o registry.2.8.3.tar
data:image/s3,"s3://crabby-images/b16cc/b16cc4e34359188c1c8db0b186b937047d7394f5" alt=""
离线安装
讲registry.2.8.3.tar
复制到目标设备上,运行下面命令导入镜像。
bash
docker load -i registry.2.8.3.tar
data:image/s3,"s3://crabby-images/dafd6/dafd66e737c3181bacecda5479ed015da6e550dc" alt=""
查询导入镜像
bash
docker images
data:image/s3,"s3://crabby-images/56ee2/56ee2043d5125b4262a5c1b7801ffcf773f88308" alt=""
启动
创建镜像存储路径
bash
mkdir -p /data/docker-registry/
data:image/s3,"s3://crabby-images/e74c3/e74c3dfd44e209ddc2a964f7b65b6e627164fdb3" alt=""
启动仓库
bash
docker run -p 5000:5000 \
--name registry \
--restart=always \
-v /data/docker-registry/:/var/lib/registry \
-d registry:2.8.3
- 服务端口为 5000,注意开放防护墙。
- 镜像存储目录为 /var/lib/registry 需要映射主机存储目录防止容器删除后镜像丢失。
data:image/s3,"s3://crabby-images/9940f/9940f4a7fde7d013b38673fb83f8e33ee1466fd0" alt=""
查看运行状态
bash
docker ps | grep registry
data:image/s3,"s3://crabby-images/19ffb/19ffb243fc9dcf27593d302afc5126326099e49e" alt=""
检查服务是否可以访问:
bash
curl 127.0.0.1:5000/v2/_catalog
仓库为空。
私有仓库设置
在需要访问该私有仓库的设备上,调整Docker配置文件/etc/docker/daemon.json
加入下面内容
json
{
"insecure-registries": [ "192.168.0.222:5000" ]
}
例如:
data:image/s3,"s3://crabby-images/f5c8c/f5c8ccd9130532156a0dbfa9039a879ff976df35" alt=""
重启Docker
bash
systemctl restart docker
data:image/s3,"s3://crabby-images/41619/4161955673b962a8a43fe9dbc9a8f47b45c15c60" alt=""
上传镜像到私有仓库
构建镜像
bash
mkdir hello_world
cd hello_world/
data:image/s3,"s3://crabby-images/07b8e/07b8eea70830a071a00702121a7119df4cedb8ff" alt=""
bash
cat > Dockerfile <<EOF
FROM scratch
EOF
data:image/s3,"s3://crabby-images/9fdc0/9fdc0762055f6f8cbe5770c797855f1ac161a9ae" alt=""
构建镜像,并打上仓库标签, 注意仓库地址替换为实际IP或域名!
bash
docker build -t 192.168.0.222:5000/myhello:1.0.0 .
data:image/s3,"s3://crabby-images/4f005/4f005feb4e7039a67f532158901cb46bd4933e4a" alt=""
推送镜像到私有仓库
bash
docker push 192.168.0.222:5000/myhello:1.0.0
推送成功
查询一下仓库中是否存在
bash
curl 127.0.0.1:5000/v2/_catalog
data:image/s3,"s3://crabby-images/5bc69/5bc69835f2046697cbc5773cdbf63093fe919a28" alt=""
从另外一台设备上从私有仓库拉取镜像
bash
docker pull 192.168.0.222:5000/myhello:1.0.0
data:image/s3,"s3://crabby-images/57111/571110b20a13f3847d8d5b33a6973072694b5a4b" alt=""
参考文献
[1]. CNCF . Distribution Registry . 2024 . https://distribution.github.io/distribution/
[2]. yeasy . docker------入门到实践 . https://yeasy.gitbook.io/docker_practice/repository/registry
[3]. 博客园 . 持久化docker的镜像或容器的方法 . 飞天小子 . 2018.12 . https://www.cnblogs.com/zhuochong/p/10064350.html