本地镜像发布到私有库

158 阅读2分钟

我们知道,一些私密的镜像不能发布到网上公开,那怎么办呢?下面我们来学习将本地镜像发布到私有库。

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

image.png

是什么

Docker Registry

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

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

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

将本地镜像推送到私有库

1.下载镜像Docker Registry

docker pull registry

2.运行私有库Registry,相当于本地有个私有Docker Hub

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

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

3.案例演示创建一个新镜像,ubuntu安装ifconfig命令

从Hub上下载ubuntu镜像到本地并成功运行

原始的Ubuntu镜像是不带着ifconfig命令的

外网连通的情况下,安装ifconfig命令并测试通过

apt-get update
​
apt-get install net-tools

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

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

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

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

docker tag 镜像:Tag Host:Port/Repository:Tag

5.将新镜像修改符合私服规范的Tag

6.修改配置文件使之支持http

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

7.push推送到私服库

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