Docker基础-3.本地镜像发布与容器数据卷

        我们在上一章中生成了自己的镜像: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

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值