暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

容器数据卷

爱德华的奇妙生活 2020-07-24
215

什么是容器数据卷

docker的理念回顾

将应用和环境打包成一个镜像!

数据?如果数据都在容器里面,那么我们删除容器,相当于将数据进行删除,这就引发了一个需求:数据需要持久化。

MySQL容器删除了,等于删库跑路,进一步带来了另一个需求:MySQL的数据可以存储在本地。

解决方案:容器之间可以有一个数据共享的技术!docker容器中产生的数据,同步到本地,这就是卷技术!目录的挂载,将我们容器内的目录,挂载到Linux上面!

一句话:容器的持久化和同步操作,容器间也是可以数据共享的

使用数据卷

方式一:直接使用命令挂载 -v

    docker run -it -v 主机目录:容器内目录


    #测试
    [root@vultr home]# docker run -it -v home/ceshi:/home centos bin/bash


    #通过docker inspect 容器id 来查看容器信息

    关闭容器后,只要不删除容器,在宿主机上修改文件,容器内的数据依旧是可以同步的。

    这样的话,就可以应用在修改nginx配置文件,我们不必每次都进入到容器内,只需要将其挂载出来,提供一个外部的映射路径,这样就可以在外部进行修改,容器内自动同步。

    安装MySQL

    思考:思考数据持久化问题

      #获取镜像
      [root@vultr home]# docker search mysql
      [root@vultr home]# docker pull mysql:5.7


      #运行容器的时候,挂载数据
      #安装配置MySQL,需要配置密码
      -d 后台运行
      -p 端口映射
      -v 卷挂载
      -e 环境配置
      --name 容器名字
      [root@vultr home]# 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=123456 --name msyql01 mysql:5.7


      #启动成功后,可以在本地使用Navicat Premium测试连接成功
      #Navicat Premium ---连接到服务器的3310----3310连接到和容器内的3306映射----这个时候就连接成功了




      #在本次创建数据库,测试发现同步是成功的

      当把容器删除

      发现,挂载到本地的数据卷依旧没有丢失,这就实现了数据持久化功能。

      具名挂载和匿名挂载

        #匿名挂载
        —v 容器内路径
        docker run -d -P --name nginx01 -v etc/nginx nginx


        #查看所有的卷的情况
        [root@vultr home]# docker volume ls
        #这就是匿名挂载,我们在-v只写了容器内的路径,没有写容器外的路径!

          #具名挂载
          [root@vultr home]# docker run -d -P --name nginx02 -v juming-nginx:/etc/nginx nginx
          #通过 -v 卷名:容器内路径
          #查看一下这个卷


          [root@vultr home]# docker volume inspect juming-nginx
          [
          {
          "CreatedAt": "2020-07-23T19:40:05+08:00",
          "Driver": "local",
          "Labels": null,
          "Mountpoint": "/var/lib/docker/volumes/juming-nginx/_data",
          "Name": "juming-nginx",
          "Options": null,
          "Scope": "local"
          }
          ]
          #所有docker容器内的卷,没有指定目录的情况下,都是在/var/lib/docker/volumes/xxx/_data

          通过具名挂载可以清楚地找到自己的卷,所以大多数情况下推荐使用具名挂载

            #如何确定是具名挂载还是匿名挂载,还是指定路径挂载
            -v 容器内路径 #匿名挂载
            -v 卷名:容器内路径 #具名挂载
            -v /宿主机路径:容器内路径 #指定路径挂载

            扩展:

              # 通过 -v 容器内路径:ro rw 改变读写权限
              ro #只读
              rw #只写


              #一旦这个设置了容器权限,容器对我们挂载出来的内容就有限定了
              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就说明这个路径只能通过宿主机来操作,容器内部是无法操作的

              数据卷容器

              多个MySQL同步数据

              启动三个容器,通过刚才自己写的镜像启动

              启动docker03


              通过--volumes-from可以实现容器间的数据共享。

              即便是删除了docker01,docker02、docker03内的数据依旧存在。

              容器之间配置信息的传递,数据卷容器的生命周期一直持续到没有容器使用为止。但是一旦持久化到了本地,这个时候,本地的数据是不会删除的。

              文章转载自爱德华的奇妙生活,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

              评论