我们在上一章中生成了自己的镜像:myubuntu,这章分别将它发布到阿里云和私有仓库
docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
myubuntu 1.0 938b4fc0baf5 20 minutes ago 179MB
一、本地镜像发布到阿里云
首先登录该网站->控制台->云服务器ECS->容器镜像服务->创建个人实例 ->创建命名空间->创建个人仓库->查看脚本及示例
开放云原生应用-云原生(Cloud Native)-云原生介绍 - 阿里云
接下来推送本地的镜像
docker images
#REPOSITORY TAG IMAGE ID CREATED SIZE
#myubuntu 1.0 938b4fc0baf5 20 minutes ago 179MB
docker login --username=aliyun1314127743 registry.cn-chengdu.aliyuncs.com
#Password:
#Login Succeeded
docker tag 938b4fc0baf5 registry.cn-chengdu.aliyuncs.com/wz_study/docker_study:1.0
docker push registry.cn-chengdu.aliyuncs.com/wz_study/docker_study:1.0
#The push refers to repository [registry.cn-chengdu.aliyuncs.com/wz_study/docker_study]
#aaf7dceefb7e: Pushed
#9f54eef41275: Pushed
#1.0: digest: sha256:270b01b377a1a7f0a3daac0a33ca389deeb373c53f66d76600335c4109c64864 size: 741
从远程库拉取镜像
docker images
#REPOSITORY TAG IMAGE ID CREATED SIZE
#redis latest 7614ae9453d1 8 months ago 113MB
#ubuntu latest ba6acccedd29 10 months ago 72.8MB
#hello-world latest feb5d9fea6a5 11 months ago 13.3kB
docker pull registry.cn-chengdu.aliyuncs.com/wz_study/docker_study:1.0
#1.0: Pulling from wz_study/docker_study
#7b1a6ab2e44d: Already exists
#65a6e47fb1c7: Already exists
#Digest: sha256:270b01b377a1a7f0a3daac0a33ca389deeb373c53f66d76600335c4109c64864
#Status: Downloaded newer image for registry.cn-#chengdu.aliyuncs.com/wz_study/docker_study:1.0
#registry.cn-chengdu.aliyuncs.com/wz_study/docker_study:1.0
docker images
#REPOSITORY TAG IMAGE ID CREATED #SIZE
#registry.cn-chengdu.aliyuncs.com/wz_study/docker_study 1.0 938b4fc0baf5 44 minutes ago 179MB
#redis latest 7614ae9453d1 8 months ago 113MB
#ubuntu latest ba6acccedd29 10 months ago 72.8MB
#hello-world latest feb5d9fea6a5 11 months ago 13.3kB
二、本地镜像发布到私有库
Docker Registry是官方提供的工具,可以用于构建私有镜像仓库
1.下载镜像Docker Registry
docker pull registry
2.运行Docker Registry,默认情况,仓库被创建在容器的/var/lib/registry目录下,建议自行用容器卷(下节讲)映射,方便于宿主机联调
docker run -d -p 5000:5000 -v /usr/myregistry/:/tmp/registry --privileged=true registry
3.演示修改原始Ubuntu镜像,增加ifconfig功能
#容器外
docker run -it ubuntu /bin/bash
#容器内
apt-get update
apt-get install net-tools
#容器外
docker commit -m="ifconfig add" -a="wz" 8f3c3ae1e09d myubuntu:1.1
4. 看私服上有什么镜像(空的)
curl -XGET http://192.168.80.128:5000/v2/_catalog
5. 修改镜像的tag
按照公式: docker tag 镜像:Tag Host:Port/Repository:Tag
docker tag myubuntu:1.1 192.168.80.128:5000/myubuntu:1.1
6.修改配置文件使其支持http
vim /etc/docker/daemon.json
{
"registry-mirrors": ["https://aa25jngu.mirror.aliyuncs.com"],
"insecure-registries": ["192.168.111.162:5000"]
}
docker默认不允许http方式推送镜像,通过配置选项来取消这个限制。====> 修改完后如果不生效,建议重启docker
7.推送到私服
docker push 192.168.80.128:5000/myubuntu:1.1
8.再次执行步骤4,查看是否推送上了
9.拉取镜像到本地
docker pull 192.168.80.128:5000/myubuntu:1.1
三、Docker容器数据卷
我们在上一节的演示中的docker run命令中使用了如下参数
-v /usr/myregistry/:/tmp/registry --privileged=true
这就代表使用了数据卷,使容器与主机共享数据。
3.1 什么是容器卷
卷就是目录或文件,存在于一个或多个容器中,由docker挂载到容器,但不属于联合文件系统,因此能够绕过Union File System提供一些用于持续存储或共享数据的特性。
Docker容器产生的数据,如果不备份,那么当容器实例删除后,容器内的数据自然也就没有了。
卷的设计目的就是数据的持久化,完全独立于容器的生存周期,因此Docker不会在容器删除时删除其挂载的数据卷。
一句话来说,有点类似我们Redis里面的rdb和aof文件,将docker容器内的数据保存进宿主机的磁盘中。
特点:
1:数据卷可在容器之间共享或重用数据
2:卷中的更改可以直接实时生效,爽
3:数据卷中的更改不会包含在镜像的更新中
4:数据卷的生命周期一直持续到没有容器使用它为止
3.2 怎么使用
使用格式:
docker run -it --privileged=true -v /宿主机绝对路径目录:/容器内目录 镜像名
默认情况下容器实例与主机之间数据是共享的,假如我们希望容器实例这边是只读的,可以这样设置:
docker run -it --privileged=true -v /宿主机绝对路径目录:/容器内目录:ro 镜像名
假如我们希望容器2继承容器1的卷规则呢?(容器2->容器1->主机)
docker run -it --privileged=true --volumes-from 容器1名 --name 容器2名 镜像名
怎么查看容器卷是否挂载成功呢?
docker inspect 容器ID