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

  • 本地镜像发布到私有库流程e44246f906c4420abe4309caf0371cfd.png
  •  

  • 是什么
  • 1 官方Docker Hub地址:https://hub.docker.com/,中国大陆访问太慢了且准备被阿里云取代的趋势,不太主流。
  • 2 Dockerhub、阿里云这样的公共镜像仓库可能不太方便,涉及机密的公司不可能提供镜像给公网,所以需要创建一个本地私人仓库供给团队使用,基于公司内部项目构建镜像。
  • Docker Registry是官方提供的工具,可以用于构建私有镜像仓库
  •  
  • 将本地镜像推送到私有库
    • 下载镜像Docker Registry
docker pull registry 
  • 7399397e2f4e487b93de518bd932c120.png
  • 运行私有库Registry,相当于本地有个私有Docker hub
docker run -d -p 5000:5000 -v /myregistry/:/tmp/registry --privileged=true registry

 

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

 

  • 案例演示创建一个新镜像,ubuntu安装ifconfig命令
    • 原始的Ubuntu镜像是不带着ifconfig命令的
    • 从Hub上下载ubuntu镜像到本地并成功运行
    • 原始的Ubuntu镜像是不带着ifconfig命令的

 

  • 外网连通的情况下,安装ifconfig命令并测试通过02cacf41e97242729408cf079cd9fb17.png

 docker容器内执行上述两条命令:

apt-get update

apt-get install net-tools

8cad7d5a99924680b799fb50106ea77e.png

 

安装完成后,commit我们自己的新镜像

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

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

docker commit -m="ifconfig cmd add" -a="wx" a69d7c825c4f wxubuntu:1.2

 

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

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

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

 

3dba45d6e9bf4e218c01fc1718b3271a.png

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

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

7cdac0c963704c41bbaf1a8e20b24037.png

 

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

将新镜像myubuntu:1.2修改符合私服规范的Tag

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

自己host主机IP地址,填写你们自己的,不要粘贴错误

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

docker tag  myubuntu:1.2  192.168.239.133:5000/myubuntu:1.2

 

aa50ad71ea1843e6ab23dc41794234ba.png

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

别无脑照着复制,registry-mirrors 配置的是国内阿里提供的镜像加速地址,不用加速的话访问官网的会很慢。

2个配置中间有个逗号 ','别漏了,这个配置是json格式的。

2个配置中间有个逗号 ','别漏了,这个配置是json格式的。

2个配置中间有个逗号 ','别漏了,这个配置是json格式的。

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

7001f47492044451b9836defd7373383.png

 上述理由:docker默认不允许http方式推送镜像,通过配置选项来取消这个限制。====> 修改完后如果不生效,建议重启docker

这里报错了

f9c1dacd50c84a64b540108f7bd0eabe.png

 先去docke ps -a 查看一下

docker里registry端口映射服务关闭了

c0d93614c3b04298a140377d68d6d20c.png

解决:开启映射

0c8a6900dc9f466f870f7113845e04e5.png 

  • push推送到私服库c05d0186117c44d0b8cdab30033a7b3a.pngcurl验证私服库上有什么镜像
  • 837d7d87c31742d285494972b64eb3fe.png
  • pull到本地并运行d8dc2c7f8ecd4d0caaa224abba0d8b0e.png

 

 

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Docker镜像管理和私有仓库建构是Docker的重要组成部分。镜像管理是指如何管理和维护Docker镜像,包括创建、删除、更新和查看镜像等操作。私有仓库建构是指如何建立自己的Docker仓库,用于存放和分享自己的Docker镜像。 以下是关于Docker容器镜像管理和私有仓库建构的一些基本知识点: 1. 镜像管理 Docker镜像是一个可执行的软件包,包含了运行某个应用程序所需的所有文件和依赖项。Docker镜像可以基于已有的镜像创建,也可以从Dockerfile构建。 基于已有的镜像创建新的镜像: ``` docker commit [CONTAINER_ID] [NEW_IMAGE_NAME] ``` 从Dockerfile构建新的镜像: ``` docker build -t [IMAGE_NAME] [DOCKERFILE_PATH] ``` 查看本地所有镜像: ``` docker images ``` 删除本地指定的镜像: ``` docker rmi [IMAGE_NAME] ``` 2. 私有仓库建构 Docker Hub是一个公共的Docker仓库,但是有时候我们需要建立自己的私有仓库,用于存放和分享自己的Docker镜像Docker官方提供了Docker Registry来搭建私有仓库,也可以使用第三方工具如Nexus、GitLab等来搭建私有仓库。 使用Docker Registry搭建私有仓库: ``` docker run -d -p 5000:5000 --name registry registry:2 ``` 在Dockerfile中指定私有仓库地址: ``` FROM [PRIVATE_REGISTRY]:[PORT]/[IMAGE_NAME]:[TAG] ``` 将本地镜像推送私有仓库: ``` docker tag [LOCAL_IMAGE_NAME] [PRIVATE_REGISTRY]:[PORT]/[IMAGE_NAME]:[TAG] docker push [PRIVATE_REGISTRY]:[PORT]/[IMAGE_NAME]:[TAG] ``` 从私有仓库拉取镜像: ``` docker pull [PRIVATE_REGISTRY]:[PORT]/[IMAGE_NAME]:[TAG] ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值