本地镜像发布到私有库
- 1、私有库是什么?
- 2、将本地镜像推送到私有库实践
- 2.1 下载镜像Docker Registry
- 2.2 运行私有库
- 2.3 制作一个新镜像
- 2.4 curl验证私服库上有什么镜像
- 2.5 将新镜像xttubuntu:1.2修改符合私服规范的Tag
- 2.6 修改配置文件使docker支持http
- 2.7 push推送到私服库
- 2.8 curl验证私服库上是否有推送的镜像
- 2.9 将私有库的镜像拉取到本地并运行
1、私有库是什么?
通常我们是将自己的镜像发布到Docker Hub:https://hub.docker.com/,但是中国大陆访问太慢了且准备被阿里云取代的趋势,不太主流。
Dockerhub、阿里云这样的公共镜像仓库可能不太方便,涉及机密的公司不可能提供镜像给公网,所以需要创建一个本地私人仓库供给团队使用,基于公司内部项目构建镜像。
Docker Registry是官方提供的工具,可以用于构建私有镜像仓库
2、将本地镜像推送到私有库实践
2.1 下载镜像Docker Registry
2.2 运行私有库
运行私有库,相当于本地有个Docker Hub
默认情况,仓库被创建在容器的/var/lib/registry目录下,建议自行用容器卷映射,方便于宿主机联调
2.3 制作一个新镜像
这里我们创建一个新镜像,ubuntu安装ifconfig命令
1、从Hub上下载ubuntu镜像到本地并成功运行
默认镜像中是没有ifconfig命令的
安装ifconfig命令
安装完成之后,commit我们自己的新镜像
命令:
在容器外面执行
启动我们的新镜像并和原来的对比
官网是默认下载的Ubuntu没有ifconfig命令我们自己commit构建的新镜像,新增加了ifconfig功能,可以成功使用
2.4 curl验证私服库上有什么镜像
空的,没有什么镜像。
2.5 将新镜像xttubuntu:1.2修改符合私服规范的Tag
命令格式:
使用命令 docker tag 将xttubuntu:1.2 这个镜像修改为192.168.159.33:5000/xttubuntu:1.2
2.6 修改配置文件使docker支持http
docker默认不允许http方式推送镜像,通过配置选项来取消这个限制
根据自己情况修改,修改完成之后重启docker
2.7 push推送到私服库
2.8 curl验证私服库上是否有推送的镜像
可以看到,镜像推送成功了。
2.9 将私有库的镜像拉取到本地并运行
在此之前先将我们本地的镜像删除掉
拉取私有库中的镜像
启动镜像并测试我们之前安装的ifconfig命令是否可用
可以看到,之前的ifconfig命令也是可用的,Docker果然很强大啊,这样就不存在测试和开发扯皮的事情了。