06第六章:本地镜像发布到私有库
作者:互联网
一、本地镜像发布到私有库流程
![](https://files.mdnice.com/user/27110/78b5bb9c-610e-43ef-b723-eede9308edea.png)
二、Docker Registry 是什么
(1)官方 Docker Hub 地址:https://hub.docker.com/,中国大陆访问太慢了且准备被阿里云取代的趋势,不太主流。
(2)Dockerhub、阿里云这样的公共镜像仓库可能不太方便,涉及机密的公司不可能提供镜像给公网,所以需要创建一个本地私人仓库供给团队使用,基于公司内部项目构建镜像。
(3)Docker Registry 是官方提供的工具,可以用于构建私有镜像仓库
三、将本地镜像推送到私有库
1、下载镜像 Docker Registry
![](https://files.mdnice.com/user/27110/21b31b43-c07f-427a-a424-ac0e06d38bf5.png)
![](https://files.mdnice.com/user/27110/02b8eb48-e17d-4975-a6c8-05a9d252dea5.png)
2、运行私有库 Registry,相当于本地有个私有 Docker hub
docker run -d -p 5000:5000 -v /njfuser/myregistry/:/tmp/registry --privileged=true registry
默认情况,仓库被创建在容器的/var/lib/registry 目录下,建议自行用容器卷映射,方便于宿主机联调
![](https://files.mdnice.com/user/27110/48453d80-7ad7-46f2-b2eb-ed6fec5878ea.png)
3、案例演示创建一个新镜像,ubuntu 安装 ifconfig 命令
(1)从 Hub 上下载 ubuntu 镜像到本地并成功运行
(2)原始的 Ubuntu 镜像是不带着 ifconfig 命令的
![](https://files.mdnice.com/user/27110/29083109-956e-47e7-9d3d-dfabce3e0c6f.png)
(3)外网连通的情况下,安装 ifconfig 命令并测试通过
docker容器内执行上述两条命令:
apt-get update
apt-get install net-tools
![](https://files.mdnice.com/user/27110/f31d50ca-1114-4efe-8d3a-6ff4d1121de3.png)
![](https://files.mdnice.com/user/27110/0b4632ba-95e0-4de2-ab14-203437e63840.png)
(4)安装完成后,commit 我们自己的新镜像
公式:
docker commit -m="提交的描述信息" -a="作者" 容器ID 要创建的目标镜像名:[标签名]
命令:在容器外执行,记得
docker commit -m="ifconfig cmd add" -a="zzyy" a69d7c825c4f zzyyubuntu:1.2
![](https://files.mdnice.com/user/27110/e16d9f95-afa8-4c8d-935c-dfdf3d4d9d16.png)
(5)启动我们的新镜像并和原来的对比
官网是默认下载的 Ubuntu 没有 ifconfig 命令,我们自己 commit 构建的新镜像,新增加了 ifconfig 功能,可以成功使用。
![](https://files.mdnice.com/user/27110/722af2f7-1f48-4579-bee1-4e053da6e633.png)
4、curl 验证私服库上有什么镜像
curl -XGET http://192.168.10.100:5000/v2/_catalog
可以看到,目前私服库没有任何镜像上传过。。。。。。
![](https://files.mdnice.com/user/27110/74a84abd-9542-445d-92d1-660bbb803049.png)
5、将新镜像 myubuntu:1.2 修改符合私服规范的 Tag
按照公式: docker tag 镜像:Tag Host:Port/Repository:Tag
自己 host 主机 IP 地址,填写同学你们自己的,不要粘贴错误
使用命令 docker tag 将 myubuntu:1.2 这个镜像修改为 192.168.10.100:5000/myubuntu:1.2
docker tag myubuntu:1.2 192.168.10.100:5000/myubuntu:1.2
![](https://files.mdnice.com/user/27110/303ff6f6-31ab-4836-9022-89bfec2ea218.png)
6、修改配置文件使之支持 http
![](https://files.mdnice.com/user/27110/b5600bd0-5f88-4417-bc0d-46ab750e564b.png)
别无脑照着复制,registry-mirrors 配置的是国内阿里提供的镜像加速地址,不用加速的话访问官网的会很慢。2 个配置中间有个逗号 ','别漏了,这个配置是 json 格式的。
vim 命令新增如下红色内容:vim /etc/docker/daemon.json
{
"registry-mirrors": ["https://aa25jngu.mirror.aliyuncs.com"],
"insecure-registries": ["192.168.10.111:5000"]
}
上述理由:docker 默认不允许 http 方式推送镜像,通过配置选项来取消这个限制。====> 修改完后如果不生效,建议重启 docker
重启完 Docker 后需要重新运行 Registry 镜像!
7、push 推送到私服库
docker push 192.168.10.100:5000/myubuntu:1.2
![](https://files.mdnice.com/user/27110/2cf66ddc-5449-4d3d-b9f5-868d19cb15f9.png)
![](https://files.mdnice.com/user/27110/9dbd7bcf-75dd-46ae-895e-bf6cd885da20.png)
8、curl 验证私服库上有什么镜像
curl -XGET http://192.168.10.100:5000/v2/_catalog
![](https://files.mdnice.com/user/27110/107885bd-ec5e-40ad-852c-bc385f4d8f7b.png)
9、pull 到本地并运行
docker pull 192.168.10.100:5000/myubuntu:1.2
![](https://files.mdnice.com/user/27110/4dc35cc0-6a61-4a3c-8303-2ecb3bee202d.png)
![](https://files.mdnice.com/user/27110/eaf4a622-21ef-4f66-b429-63f26dc751de.png)
运行镜像:
docker run -it 192.168.10.100:5000/myubuntu:1.2 /bin/bash
![](https://files.mdnice.com/user/27110/92d4ef85-13a8-4c65-b864-c7c5735582d0.png)
![](https://files.mdnice.com/user/27110/6a991439-c48b-430b-ad2d-e448e5321874.png)
标签:5000,06,1.2,192.168,myubuntu,第六章,镜像,docker 来源: https://www.cnblogs.com/niujifei/p/16652377.html