Docker数据卷(volume)

本文详细介绍了Docker数据卷的概念及其解决容器数据管理难题的方法,包括数据卷的创建、使用、备份与恢复流程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 Docker的镜像是由一系列的只读层组合而来,当启动一个容器的时候,Docker加载镜像的所有只读层,并在最上层加入一个读写层。这个设计使得Docker可以提高镜像构建、存储和分发的效率,节省了时间和存储空间,然而也存在如下问题。

   (1)容器中的文件在宿主机上存在形式复杂,不能在宿主机上很方便的对容器中的文件进行访问

   (2)多个容器之间的数据无法共享

    (3)当删除容器时,容器产生的数据将丢失

    为了解决这些问题,Docker引入了数据卷(volume)机制。volume是存在一个或多个容器中的特定文件或文件夹,这个目录能够独立于联合文件系统的形式在宿主机中存在,并为数据的共享与持久提供一下便利。

    (1)volume在容器创建时就初始化,在容器运行时就可以使用其中的文件

    (2)volume能在不同的容器之间共享和重用

     (3)对volume中的数据的操作会马上生效

   (4)对volume中数据操作不会影响到镜像本身

   (5)volume的生存周期独立于容器的生存周期,即使删除容器,volume仍然会存在,没有任何容器使用的volume也不会被Docker删除

1.运行镜像产生容器:

docker run -it --name micheal:v1.0 -v /home/tmp:/home/tmp docker_demo /bin/bash

-d:后台运行

-v:挂在数据卷 使用:ro设置挂在数据卷为只读。如: docker run -it --name micheal:v1.0 -v /home/tmp:/home/tmp:ro docker_demo /bin/bash

当使用-v不指名宿主机的挂在路径的话docker会自行进行分配路径进行挂载;如:


使用命令:docker inspect demo2查看docker自动分配的挂载数据卷位置


多个容器共用一个宿主挂载点:如下命令所示



那么第二条命令 docker_demo4就不会创建成功会出现错误。如果想要新的容器和其他容器共用同一个宿主挂载点那么就只有需要下面的命令:及“--volumes-from 容器名称


  如果挂载源有多个时,可以使用多个--volumes-from相互间隔连接。


2.备份、恢复或迁移volume

   上面有测试过,当使用docker commit等手段生成新镜像,然后再启动镜像生成新容器时,原先volume目录下的文件不见了,可以生成新镜像时,并没有把volume下的文件一起打包生成镜像。

   volume作为数据的载体,在很多情况下需要对其中的数据进行备份、迁移,或是从已有数据恢复。一个很容易想到的方法就是用docker inspect命令查找到volume对应宿主机上对应的那个目录位置,然后复制其中内容或使用tar打包。当这些笨拙的做法并不值得推荐,因为查找主机上文件夹后再操作容易出错,也不适合脚本的自动化执行。

   备份volume可以使用以下方法

   docker run --rm --volumes-from dbdata -v $(pwd):/backup test/mycentos:v1.0 tar cvf /back/data.tar /data

  这行指令启动了一个临时的容器,这个容器挂载了两个volume,第一个volume与要备份的volume共享,第二个volume将宿主机的当前目录(也可以绝对路径)挂载到容器的/backup下。容器运行后将要备份的容器(/data)备份到/backup/data.tar,然后删除容器,备份后的data.tar就留在了当前目录。操作验证一下












评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值