1.准备一台服务器A(已安装docker, IP:192.168.39.111)
2.在服务器A上通过运行registry容器进行搭建
docker run -itd -v /my_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下来的镜像;
3.在本地主机B上配置"不安全注册表" 即:http的连接(已安装docker,IP:192.168.39.215)
编辑该daemon.json
文件,其默认位置 /etc/docker/daemon.json
在Linux或C:\ProgramData\docker\config\daemon.json
Windows Server上。如果您使用Docker Desktop for Mac或Docker Desktop for Windows,请单击Docker图标,选择 Preferences,然后选择+ Daemon。
如果该daemon.json
文件不存在,请创建它。添加一下内容后重启systemctl restart docker 假设文件中没有其他设置,则应具有以下内容:
{ "insecure-registries" : ["myregistrydomain.com:5000"] }
mac 端是如下:
4.在本地主机B上测试push和pull
- 先对镜像进行标记(标记需加ip,否则报错):docker tag busybox 192.168.39.111:5000/bbx:v1
- push镜像:docker push 192.168.39.111:5000/bbx:v1
- 第二步若成功,便可pull 拉取下来: docker pull 192.168.39.111:5000/bbx:v1
总结:注意设置"不安全的注册表"是在推送的一端设置,不是在镜像服务器端
原文地址:https://www.cnblogs.com/spotatoman/p/10987524.html
时间: 2024-10-09 15:58:19