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

二、私有库是什么
- 官方Docker Hub地址:https:///,中国大陆访问太慢了且准备被阿里云取代的趋势,不太主流。
- Dockerhub、阿里云这样的公共镜像仓库可能不太方便,涉及机密的公司不可能提供镜像给公网,所以需要创建一个本地私人仓库供给团队使用,基于公司内部项目构建镜像。
- Docker Registry是官方提供的工具,可以用于构建私有镜像仓库
三、将本地镜像推送到私有库
下载镜像Docker Registry
docker pull registry

2、运行私有库Registry,相当于本地有个私有Docker hub
默认情况,仓库被创建在容器的/var/lib/registry目录下,建议自行用容器卷映射,方便于宿主机联调
命令
# 1.创建宿主机目录/data/registry/
# 2.指向registry容器的默认目录/var/lib/registry
# 这个过程属于挂载
docker run -d -p 5000:5000 -v /data/registry/:/var/lib/registry --privileged=true registry

3、案例
演示创建一个新镜像,Ubuntu安装ifconfig命令
3.1、从Docker Hub上下载Ubuntu到本地并成功运行

3.2、原始的Ubuntu镜像是不带着ifconfig命令的
容器内执行:外网连通命令
apt-get update
apt-get install net-tools


3.3、外网连通的情况下,安装ifconfig命令并测试通过
命令
# 公式:
docker commit -m="提交的描述信息" -a="作者" 容器ID 要创建的目标镜像名:[标签名]
# 命令:在容器外执行,记得
docker commit -m="ifconfig cmd add" -a="zzyy" a69d7c825c4f zzyyubuntu:1.23.4、安装完成后,commit我们自己的新镜像

3.5、启动我们的新镜像并和原来的对比
- 官网是默认下载的Ubuntu没有ifconfig命令
- 我们自己commit构建的新镜像,新增加了ifconfig功能,可以成功使用。

4、curl验证私服库有什么镜像
命令
# 只需要变更你的本地ip
curl -XGET http://175.178.40.236:5000/v2/_catalog可以看到,当前私服库镜像为空

5、将新镜像myubuntu:1.2修改符号私有规范的TAG
命令
docker tag [镜像]:[TAG] [HOST]:[PORT]/[镜像]:[TAG]
# 举例
docker tag myubuntu:1.2 175.178.40.236:5000/myubuntu:1.2

修改配置文件使之支持http
{
# 一开始配置的,阿里云镜像加速器
"registry-mirrors": ["https://4rq8j6kx.mirror.aliyuncs.com"],
# 需要配置内容
"insecure-registries": ["175.178.40.236:5000"]
}

、
注意:
- 配置中注意有个逗号(,)
- docker默认不允许http方式推送镜像,通过配置选项来取消这个限制。====> 修改完后如果不生效,建议重启docker
push推送到私服库
docker push 175.178.40.236:5000/myubuntu:1.2

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

pull到本地并运行
# 删除原有镜像,重新拉取
docker pull 175.178.40.236:5000/myubuntu:1.2


















