Docker 本地镜像发布到私有仓库

1. 本地镜像发布到私有库流程

 

2. 是什么

1 官方Docker Hub地址:https://hub.docker.com/,中国大陆访问太慢了且准备被阿里云取代的趋势,不太主流。

2 Dockerhub、阿里云这样的公共镜像仓库可能不太方便,涉及机密的公司不可能提供镜像给公网,所以需要创建一个本地私人仓库供给团队使用,基于公司内部项目构建镜像。

Docker Registry是官方提供的工具,可以用于构建私有镜像仓库

3. 将本地镜像推送到私有库

3.1 下载镜像Docker Registry

docker pull registry 

 

 

3.2 运行私有库Registry,相当于本地有个私有Docker hub

docker run -d -p 5000:5000  -v /zzyyuse/myregistry/:/tmp/registry --privileged=true registry

默认情况,仓库被创建在容器的/var/lib/registry目录下,建议自行用容器卷映射,方便于宿主机联调

 

3.3 案例演示一个创建一个新的镜像

1. 从hub上下载ubuntu镜像到本地并成功运行

docker pull ubuntu

 

2. 原始的ubuntu镜像是不带ifconfig命令

3. 外网联通情况下,安装ifconfig命令并通过测试

apt-get update

apt-get install net-tools

 

 

 

4. 安装完成后,commit我们自己的新景象

docker commit -m="提交的描述信息" -a="作者容器ID 要创建的目标镜像名:[标签名]

命令:在容器外执行,记得

docker commit -m="ifconfig cmd add" -a="zzyy" a69d7c825c4f zzyyubuntu:1.2

 

5. 启动我们的新镜像并和原来的对比

1 官网是默认下载的Ubuntu没有ifconfig命令

2我们自己commit构建的新镜像,新增加了ifconfig功能,可以成功使用。

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

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

 

可以看到,目前私服库没有任何镜像上传过。。。。。。


 

3.5 将新镜像 zzyyubuntu:1.2 修改符合规范的tag

按照公式: docker   tag   镜像:Tag   Host:Port/Repository:Tag

自己host主机IP地址,填写同学你们自己的,不要粘贴错误,O(∩_∩)O

使用命令 docker tag 将zzyyubuntu:1.2 这个镜像修改为192.168.111.162:5000/zzyyubuntu:1.2

 

docker tag  zzyyubuntu:1.2  192.168.111.162:5000/zzyyubuntu:1.2

 

3.6 修改配置文件使之支持http

vim命令新增如下红色内容:vim /etc/docker/daemon.json 

{

  "registry-mirrors": ["https://aa25jngu.mirror.aliyuncs.com"] ,
  "insecure-registries": ["192.168.111.162:5000"]
}
上述理由:docker默认不允许http方式推送镜像,通过配置选项来取消这个限制。====>  修改完后如果不生效,建议重启docker

3.7 push推送到私服库

docker push 192.168.111.162:5000/zzyyubuntu:1.2

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

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

 

3.9 pull到本地并运行

docker pull 192.168.111.162:5000/zzyyubuntu:1.2

docker run -it 镜像ID /bin/bash 

 

要将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
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值