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


            我们在上一章中生成了自己的镜像:myubuntu,这章分别将它发布到阿里云和私有仓库

    1. docker images
    2. REPOSITORY TAG IMAGE ID CREATED SIZE
    3. myubuntu 1.0 938b4fc0baf5 20 minutes ago 179MB

    一、本地镜像发布到阿里云

            首先登录该网站->控制台->云服务器ECS->容器镜像服务->创建个人实例 ->创建命名空间->创建个人仓库->查看脚本及示例

            开放云原生应用-云原生(Cloud Native)-云原生介绍 - 阿里云

     

     

             接下来推送本地的镜像

    1. docker images
    2. #REPOSITORY TAG IMAGE ID CREATED SIZE
    3. #myubuntu 1.0 938b4fc0baf5 20 minutes ago 179MB
    4. docker login --username=aliyun1314127743 registry.cn-chengdu.aliyuncs.com
    5. #Password:
    6. #Login Succeeded
    7. docker tag 938b4fc0baf5 registry.cn-chengdu.aliyuncs.com/wz_study/docker_study:1.0
    8. docker push registry.cn-chengdu.aliyuncs.com/wz_study/docker_study:1.0
    9. #The push refers to repository [registry.cn-chengdu.aliyuncs.com/wz_study/docker_study]
    10. #aaf7dceefb7e: Pushed
    11. #9f54eef41275: Pushed
    12. #1.0: digest: sha256:270b01b377a1a7f0a3daac0a33ca389deeb373c53f66d76600335c4109c64864 size: 741

            从远程库拉取镜像

    1. docker images
    2. #REPOSITORY TAG IMAGE ID CREATED SIZE
    3. #redis latest 7614ae9453d1 8 months ago 113MB
    4. #ubuntu latest ba6acccedd29 10 months ago 72.8MB
    5. #hello-world latest feb5d9fea6a5 11 months ago 13.3kB
    6. docker pull registry.cn-chengdu.aliyuncs.com/wz_study/docker_study:1.0
    7. #1.0: Pulling from wz_study/docker_study
    8. #7b1a6ab2e44d: Already exists
    9. #65a6e47fb1c7: Already exists
    10. #Digest: sha256:270b01b377a1a7f0a3daac0a33ca389deeb373c53f66d76600335c4109c64864
    11. #Status: Downloaded newer image for registry.cn-#chengdu.aliyuncs.com/wz_study/docker_study:1.0
    12. #registry.cn-chengdu.aliyuncs.com/wz_study/docker_study:1.0
    13. docker images
    14. #REPOSITORY TAG IMAGE ID CREATED #SIZE
    15. #registry.cn-chengdu.aliyuncs.com/wz_study/docker_study 1.0 938b4fc0baf5 44 minutes ago 179MB
    16. #redis latest 7614ae9453d1 8 months ago 113MB
    17. #ubuntu latest ba6acccedd29 10 months ago 72.8MB
    18. #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功能

    1. #容器外
    2. docker run -it ubuntu /bin/bash
    3. #容器内
    4. apt-get update
    5. apt-get install net-tools
    6. #容器外
    7. 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

    1. vim /etc/docker/daemon.json
    2. {
    3. "registry-mirrors": ["https://aa25jngu.mirror.aliyuncs.com"],
    4. "insecure-registries": ["192.168.111.162:5000"]
    5. }

             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

     

  • 相关阅读:
    鸿蒙HarmonyOS实战-ArkUI组件(页面路由)
    详解 InnoDB Cluster 主机名问题
    R语言使用dietaryindex包计算NHANES数据多种健康饮食指数 (HEI等)(1)
    SQL语言入门,语法,语句分类
    校招秋招,网申和测评阶段需要注意的问题
    第5 章 项目集管理 第6 章 项目组合管理
    Prometheus Operator 配置报警
    首届CCF GitLink开源编程夏令营,来了
    人体关键点识别易语言代码
    计算机毕业设计(附源码)python智能居家养老服务平台
  • 原文地址:https://blog.csdn.net/weixin_62427168/article/details/126657343