(五)本地镜像发布到私有库&将私有库上的镜像下载到本地

目录

一、下载镜像Docker Registry

二、运行私有库Registry

三、创建一个新镜像,例如:ubuntu安装ifonfig命令

四、curl验证私服库上有什么镜像

五、将新镜像修改符合私服规范的tag

六、修改配置文件使之支持http

七、push推送到私服库

八、curl再次验证

九、从私服库pull到本地使用


一、下载镜像Docker Registry

registry是专门用于创建私有库的镜像

docker pull registry

二、运行私有库Registry

 相当于本地有个私有的Docker hub

docker run -d -p 5000:5000 -v /bai/myregistry/:/tmp/registry --privileged=true registry
# -d 守护进程
# -p 端口映射
# -v 容器卷映射

如果不指定-v,则默认情况,仓库被创建在容器的/var/lib/registry目录下,建议自行用容器卷映射,方便于宿主机联调(本命令目录在/tmp/registry)

三、创建一个新镜像,例如:ubuntu安装ifonfig命令

1、新建一个ubuntu容器,增加ifconfig命令

docker run -it ubuntu /bin/bash
apt-get update
apt-get install net-tools

2、安装后可使用ifconfig命令

3、commit成一个镜像

# 公式
docker commit -m="提交的描述信息" -a="作者" 容器ID 要创建的目标镜像名:[标签名]
# 本案例
docker commit -m="ifconfig cmd add" -a="bai" 容器ID  baiubuntu:1.2

四、curl验证私服库上有什么镜像

 (本文中只在本机操作故ip为127.0.0.1,请根据自身情况修改)

curl -XGET http://127.0.0.1:5000/v2/_catalog

中括号中是空的,说明私服库中没有镜像呢

五、将新镜像修改符合私服规范的tag

# 公式:自己host主机IP地址,填写自己的
docker tag 镜像:Tag Host:Port/Repository:Tag
#本教程中:使用命令 docker tag 将baiubuntu:1.2 这个镜像修改127.0.0.1:5000/baiubuntu:1.2
docker tag baiubuntu:1.2 127.0.0.1:5000/baiubuntu:1.2

六、修改配置文件使之支持http

由于docker的私服库做了安全加固,一般默认不支持http协议推送镜像,所以需要取消这个限制。

cat /etc/docker/daemon.json

看过之前我写的安装docker的都知道,里边有一个registry-mirrors,配置的是国内阿里提供的镜像加速器。

编辑此文件,添加配置(本文中只在本机操作故ip为127.0.0.1,请根据自身情况添加)

vim /etc/docker/daemon.json
# 增加下边的配置
"insecure-registry":["127.0.0.1:5000"],

# 修改后重启docker服务
systemctl restart docker

# 重启docker重启后,需要再重新启动私服库

注意: 此文件为json格式,两个配置中间需要加逗号

七、push推送到私服库

docker push 127.0.0.1:5000/baiubuntu:1.2

八、curl再次验证

curl -XGET http://127.0.0.1:5000/v2/_catalog

九、从私服库pull到本地使用

因为我本地有,先删除本地的,再pull

docker pull 127.0.0.1:5000/baiubuntu:1.2

尝试运行,验证ifconfig命令

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要将Docker镜像上传到私有,需要按照以下步骤进行操作: 1. 登录到私有:使用终端或命令行界面登录到私有。这通常涉及使用"docker login"命令,并提供仓的URL、用户名和密码。 2. 构建Docker镜像:在本地环境中构建Docker镜像。可以使用Dockerfile来定义构建规则,并使用"docker build"命令进行构建。构建完成后,会生成对应的镜像ID。 3. 为镜像添加标签:为将要上传的镜像添加标签,以便将其与私有中的目标仓进行关联。使用"docker tag"命令,将本地镜像ID与目标仓名称和版本进行关联。 4. 上传镜像私有:使用"docker push"命令将带有标签的镜像上传到私有。这将使用之前的登录凭据,将镜像上传到您指定的目标仓。 5. 验证镜像上传:登录到私有,查看上传的镜像是否出现在仓中。可以使用仓的Web界面或相应的命令行工具进行验证。 需要注意以下几点: - 确保您具有上传镜像的权限,这包括正确的用户名和密码,以及私有的访问权限。 - 镜像的标签需要与目标仓名称和版本相关联,以便在上传时进行正确的识别和归类。 - 上传镜像的时间取决于网络连接的速度和镜像的大小。较大的镜像可能需要更长的时间上传。 通过按照上述步骤操作,您应该能够将Docker镜像成功上传到私有中。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

mr__bai

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值