docker高阶部分学习(一)---数据卷技术

604 阅读4分钟

Docker数据卷技术

什么是容器数据卷

docker的理念回顾:将应用和环境打包成一个镜像!

数据?如果数据都在容器中,那么我们容器删除,数据就会丢失!需求:数据可以持久化

MySQL,容器删了,删库跑路--->需求:MySQL数据可以存储在本地!

容器之间可以有一个数据共享的技术!Docker容器中产生的数据,同步到本地!

这就是卷技术!目录的挂载,将我们容器内的目录,挂载到Linux上面!

GetImage (1).png

总结:容器的持久化和同步操作!容器间也是可以实现数据共享的!

使用数据卷

  • docker run -it -v 宿主机目录: 容器目录 -p 主机端口:容器端口 容器
    
    • 实战演练

      • inspect查看同步详细信息
        • GetImage (2).png
      • 在容器中创建一个文件,看是否同步到本地文件夹
        • GetImage (3).png
        • GetImage (4).png
      • 在关闭容器的情况下,对本地文件进行修改,看修改的是不是会同步到容器中文件
        • GetImage (5).png

Mysql实战

  • 命令
docker run -d -p 3310:3306 -v /root/mysql/conf:/etc/mysql/conf.d -v /root/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql01 mysql:5.7 
  • 参数
    • -d 后台运行
    • -p 端口映射
    • -v 数据卷挂载:同步数据
    • -e 设置环境变量:这里时设置的时MySQL的登陆密码
    • --name 容器起名字

GetImage (6).png

  • 测试结果:连接成功 GetImage (7).png

遇到的问题

  • 首先使用的时mysql的最新版本:8.0----在使用navicat进行连接的时候,总是报莫名其妙的错误
    • 解决方式:换成5.7版本,没有任何问题
  • 在我们run镜像mysql的时候,没有加上-e MYSQL_ROOT_PASSWORD=123456进行密码的设置,容器一直会处于关闭状态,即使重新start也不会开启
    • 加上-e MYSQL_ROOT_PASSWORD=123456这个参数完美开启

即使我们将容器删除,我们挂载到本地的数据卷依旧没有丢失,这就实现了容器数据的持久化功能

具名挂载和匿名挂载

匿名挂载

  • -v 容器内的路径!
docker run -d --name nginx01 -v /etc/nginx nginx 
  • 这里我们发现,这种就是匿名挂载,我们在-v的后面只是写上了容器内的路径没有写容器外的路径
  • 查看所有卷的情况
docker volume ls 

GetImage (8).png

具名挂载

  • -v 挂载卷的名称:容器内的路径
docker run -d --name nginx01 -v 具名挂在名称:/etc/nginx nginx 
  • 这里我们发现,这种就是具名挂载,我们在-v的后面既写上了容器内的路径,没有容器外的路径,但是有一个名称

GetImage (9).png

docker的内容目录:/var/lib/docker

  • 所有的docker容器内的卷,没有指定目录的情况下都是在:/var/lib/docker/volume/xx/_data
  • 我们可以通过具名挂载方便的找到我们的一个卷,并且在使用卷的时候最多的使用方式就是具名挂载

GetImage (10).png

  • 如何区分时具名挂载还是匿名挂载,指定路径挂载
    • -v 容器内路径 #匿名挂载
    • -v 卷名:容器内路径 #具名挂载
    • -v /容器外路径:容器内路径 #指定路径挂载
  • 扩展
    • -v 容器内路径:ro rw 改变读写权限
    • ro readonly 只读
    • rw readwrite 可读可写 一旦设置了这个容器权限,容器对我们挂载出来的内容就有限定了. Ro 只要看到ro就说明这个路径只能通过宿主机来进行操作,容器内是无法操作的
docker run -d --name nginx01 -v 具名挂在名称:/etc/nginx:ro nginx 
docker run -d --name nginx01 -v 具名挂在名称:/etc/nginx:rw nginx 

数据卷容器

  • 实际上即使保证的容器之间的数据共享的问题

    • GetImage (14).png
    • 数据卷容器实际上就是被拷贝数据的容器(A- volumes-from ->B,B是数据卷容器)
  • 测试两个镜像之间同步

    • 首先先开三个容器

      • 创建docker01
        • GetImage (15).png
      • 创建docker02 --volumes-from docekr01
        • GetImage (16).png
      • 创建docker03 --volumes-from docekr02
        • GetImage (17).png
      • 查看docker01和docker02之间的数据共享
        • GetImage (18).png
      • 查看docker01和docker03之间的数据共享
        • GetImage (19).png
      • 接着我们将docker02删除,查看docker01和docker03之间的数据共享
        • GetImage (63).png
    • 总结:

      • GetImage (21).png

实现多个mysql之间的数据共享

docker run -d -p 3310:3306 -v /root/mysql/conf:/etc/mysql/conf.d -v /root/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql01 mysql:5.7 
docker run -d -p 3310:3306 --volumes-from mysql01 -e MYSQL_ROOT_PASSWORD=123456 --name mysql02 mysql:5.7 
  • 总结:
    • 容器之间配置信息的传递。数据卷容器的声明周期一直持续到没有容器使用位置

      • 理解:容器之间只要是共享就会数据copy,即使有的容器被删除,数据依然存在,直到所有共享 的容器都删除,数据才会被彻底删除
    • 但是一旦你持久化到了本地,这个时候,本地的数据是不会删除的。