• Docker学习重点(6)~容器数据卷



    一、容器数据卷

    1、什么是容器卷

    docker是要将应用和环境打包成一个镜像

    这样,数据就不应该在容器中,否则容器删除,数据就会丢失,这就是删库跑路

    故容器之间要有一个数据共享技术


    在Docker容器中产生的数据,同步到本地,这就是卷技术


    2、容器卷的本质:

    本质上是一个目录挂载,将容器内的目录挂载到虚拟机上


    3、容器卷挂载目录的目的:

    容器的持久化和同步操作, 实现容器间可以数据共享



    二、使用数据卷

    1、方式一:直接使用命令来挂载 —v volume卷技术

    • 命令:docker run -it -v 主机目录:容器内目录
    [root@kuangshen home]# docker run-it -v/home/ceshi:/home centos/bin/bash 
    

    • 启动起来时候我们可以通过 docker inspect 容器id

    • 新开一个窗口

    docker inspect 容器id
    

    • 找到挂载信息Mounts

    • 测试:数据同步

    • 再来测试(容器停止后,修改主机文件,再启动容器的时候,数据同样改变):

      1、停止容器

      2、宿主机上修改文件

      3、启动容器

      4、容器内的数据依旧是同步的!

    双向同步


    4、使用容器数据卷的好处:

    我们以后修改,只需在本地修改即可,容器内会自动同步!



    三、实战安装mysql

    • MySQL的数据持久化命令
    # 拉取
    docker pull mysql:5.7
    
    # 挂载
    docker run -d -p 3310:3306 -v /home/mysql/conf:/etc/mysql/conf.d -v /home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=admin --name mysql01 mysql:5.7
    
    -d 后台运行
    -p 端口映射
    -v 卷挂载
    -e 环境配置 安装启动mysql需要配置密码
    --name 容器名字
    
    • 连接测试:打开mysql的客户端工具:

    ● 如果,我们将容器mysql01删除,发现:

    • 我们挂载到本地的数据卷依然没有丢失,这就实现了容器数据持久化的功能!



    四、具名和匿名挂载

    1、匿名挂载和具名挂载的区别:

    • 匿名挂载:不写宿主机目录

    • 具名挂载:会给宿主机起一个名字

      #匿名挂载  -v 容器内路径!
      docker run -d -P --name nginx01 -v /ect/nginx nginx  
      
      #查看所有的 volume 的情况
      [root@kuangshen home]# docker volume 1s
      local 9f38292179faa178afcce54d80be99d4ddd68c91d2a68870bcece72d2b7ed061 
      #这里发现,这种就是匿名挂载,我们在—v 只写了容器内的路径,没有写容器外的路径!
      
      #具名挂载
      [root@kuangshen home]#docker run-d-P--name nginx02 -v juming-nginx:/etc/nginx nginx 
      95b809564484c8ac87d65c69643e7e67447f1c77ff9a91b93edec7003692e3a9
      
      [root@kuangshen home]# docker volume 1s 
      DRIVER VOLUME NAME 
      local  juming-nginx # 通过—v 卷名:容器内路径
      
      #查看一下这个卷 
      
      • 所有的docker容器内的卷,没有指定的目录的情况下都是在/var/lib/docker/volumes/xxx/_data

    如何确定是具名挂载还是匿名挂载,还是指定路径挂载!

    • -v 容器內路径 # 匿名挂载
    • -v 卷名:容器内路径 # 具名挂载
    • -v 宿主机路径:容器内路径 # 指定路径挂载!

    2、拓展:ro、rw

    # 通过 —v 容器内路径:ro(readonly) rw(readwrite) 改变读写权限 
    #一旦这个了设置了容器权限,容器对我们挂载出来的内容就有限定了!
    
    docker run -d -P --name nginx02 -v juming-nginx:/etc/nginx:ro nginx 
    docker run -d -P --name nginx02 -v juming-nginx:/etc/nginx:rw nginx 
    
    #ro 只要看到ro就说明这个路径只能通过宿主机来操作,容器内部是无法操作!
    



    五、初始Dockerfile

    1、(目录挂载、数据同步)方式二:DockerFile使用来构建docker镜像的文件!命令脚本!

    • 通过这个脚本可以生成镜像,镜像时一层一层的,脚本是一个一个的命令,每个命令都是一层!

    镜像是一层一层的,脚本是一行一行的

    • Dockerfile 内容:
    # 指令都是大写的、
    # 创建一个dockerfile文件,命名为Dockerfile
    #文件内容:·
    FROM centos   # 一层
    VOLUME ["volume01","volume02"]  # 一层 再创建镜像的时候就挂载出来
    CMD echo "---end---"    # 一层
    CMD /bin/bash    # 一层
    
    • 构建Dockerfile:
    docker build -f /home/docker-test-volume/dockerfile1 -t shan/centos
    

    ■ 测试:在容器内部创建一个文件

    所有的docker容器内的卷,没有指定的目录的情况下都是在/var/lib/docker/volumes/xxx/_data
    • 检查容器

    • 查看Mounts,Source对应容器外目录,匿名挂载卷

    • 测试一下,在container volume01下生成文件:

    • 在主机挂载路径下,也同样生成(数据同步)

    ● 这种方式我们未来使用的十分多,因为我们通常会构建自己的镜像!假设构建镜像时候没有挂载卷,

    手动镜像挂载 —v卷名:容器内路径!



    六、数据卷容器---多个容器数据共享

    • 多个mysql 同步数据

    1、多个容器数据共享

    数据卷的继承关系 --volumes-from

    • 创建两个容器:

    • 数据卷的继承关系:

      --volumes-from

    • 启动docker01,用之前建的shan/centos 1.0 镜像
    docker run -it --name docker01 shan/centos:1.0 # 1.0必须写
    
    docker run -it --name docker02 --volumes-from docker01 shan/centos:1.0
    

    2、数据卷共享数据是拷贝


    3、结论:

    容器之间配置信息的传递,数据卷容器的生命周期一直持续到没有容器使用为止。

    但是如果持久化到了本地,即使所有容器删除了,本地数据是不会删除的!



    ☺ 参考来源:
    狂神的B站视频《【狂神说Java】Docker最新超详细版教程通俗易懂》 https://www.bilibili.com/video/BV1og4y1q7M4



    如果本文对你有帮助的话记得给一乐点个赞哦,感谢!

  • 相关阅读:
    struts2学习笔记之校验器
    struts2学习笔记之文件上传
    在ASP.net MVC里用Jquery的Ajax功能调用相关LinqtoSQL生成的类出现错误循环引用
    Linq,企业类库,EXECL生成,Execl chart的一些基本操作记录.(一)
    记录Linq所学.
    记录一个很平常的想法.
    链表反序(C#版)
    oracle 体系结构
    Oracle的sys和system用户的区别
    数据库触发器的理解
  • 原文地址:https://www.cnblogs.com/shan333/p/16283422.html
Copyright © 2020-2023  润新知