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

docker pull 从私有镜像仓库拉取镜像 docker镜像上传到私有仓库_Docker

 

2. 是什么

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


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


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

3. 将本地镜像推送到私有库

3.1 下载镜像Docker Registry

docker pull registry 

docker pull 从私有镜像仓库拉取镜像 docker镜像上传到私有仓库_Docker_02


docker pull 从私有镜像仓库拉取镜像 docker镜像上传到私有仓库_运维_03

 

 

3.2 运行私有库Registry,相当于本地有个私有Docker hub

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

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

docker pull 从私有镜像仓库拉取镜像 docker镜像上传到私有仓库_docker_04

 

3.3 案例演示一个创建一个新的镜像

1. 从hub上下载ubuntu镜像到本地并成功运行

docker pull ubuntu

 

2. 原始的ubuntu镜像是不带ifconfig命令

docker pull 从私有镜像仓库拉取镜像 docker镜像上传到私有仓库_Docker_05

3. 外网联通情况下,安装ifconfig命令并通过测试

apt-get update

apt-get install net-tools

 

docker pull 从私有镜像仓库拉取镜像 docker镜像上传到私有仓库_docker_06

docker pull 从私有镜像仓库拉取镜像 docker镜像上传到私有仓库_Docker_07

 

 

4. 安装完成后,commit我们自己的新景象

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

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

docker commit -m="ifconfig cmd add" -a="zzyy" a69d7c825c4f zzyyubuntu:1.2

docker pull 从私有镜像仓库拉取镜像 docker镜像上传到私有仓库_Docker_08

 

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

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

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

docker pull 从私有镜像仓库拉取镜像 docker镜像上传到私有仓库_ubuntu_09

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

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

 

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

docker pull 从私有镜像仓库拉取镜像 docker镜像上传到私有仓库_运维_10

 

3.5 将新镜像 zzyyubuntu:1.2 修改符合规范的tag

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

自己host主机IP地址,填写同学你们自己的,不要粘贴错误,O(∩_∩)O

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

 

docker tag  zzyyubuntu:1.2  192.168.111.162:5000/zzyyubuntu:1.2

docker pull 从私有镜像仓库拉取镜像 docker镜像上传到私有仓库_ubuntu_11

 

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

docker pull 从私有镜像仓库拉取镜像 docker镜像上传到私有仓库_运维_12


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

{

,

  "insecure-registries": ["192.168.111.162:5000"]

}


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

3.7 push推送到私服库

docker push 192.168.111.162:5000/zzyyubuntu:1.2

docker pull 从私有镜像仓库拉取镜像 docker镜像上传到私有仓库_运维_13

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

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


docker pull 从私有镜像仓库拉取镜像 docker镜像上传到私有仓库_容器_14

 

3.9 pull到本地并运行

docker pull 192.168.111.162:5000/zzyyubuntu:1.2

docker pull 从私有镜像仓库拉取镜像 docker镜像上传到私有仓库_docker_15

docker run -it 镜像ID /bin/bash 

docker pull 从私有镜像仓库拉取镜像 docker镜像上传到私有仓库_ubuntu_16