Docker实践学习(七)

本文深入探讨Docker数据卷的概念,解析数据卷如何实现数据持久化及容器间的数据共享,对比bind mount与volume的不同,介绍数据卷容器的创建与使用,以及数据卷的备份与恢复方法。

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

Docker的持久化存储和数据共享

容器删除后,任何写到容器但没有保存到数据卷的数据都会和容器一同删除。为了不让数据随着container的消失而消失,保证数据的安全性,这就有了Volume的存在。例如:数据库容器,数据表的表会产生一些数据。

数据卷

数据卷是经过特殊设计的目录,可以绕过联合文件系统,为一个或多个容器提供服务。其目的在于数据的持久化,完全独立于与容器的生命周期,因此,Docker不会在容器删除的同时删除其挂载的数据卷,也不会存在类似的垃圾收集机制,对容器引用的数据卷进行处理。

数据卷的架构理解:

1.独立于docker的存在。存在与宿主机中。与docker容器的生存在周期是分离的。
2.本质上使存在于宿主机的文件系统中
3.docker数据卷可以是目录,也可以是文件。
4.docker容器可以利用数据卷的技术可以与宿主机进行数据共享。
5.同一个目录或者文件,可以支持多个容器的访问。实现了容器间的数据进行交换。

特点:

1.数据卷在容器启动时初始化,如果容器使用的镜像在挂载点包含了包含了数据,这些数据会拷贝到新初始化的数据卷中。
2.数据卷可以在容器之间共享和重用
3.可以对数据卷里的内容直接进行修改
4.数据卷的变化不会影响镜像的更新
5.数据卷会一直存在,即使挂载数据卷的容器已经被删除

数据卷容器

一个命名的容器挂载数据卷,其他容器通过挂载这个容器实现数据共享,挂载数据卷的容器,就叫做数据卷容器。

数据卷存储形式

docker 主要有两种数据存储形式, 一种是storage driver(也叫做 Graph driver), 另一种是 volume driver. stroage driver主要是存储那些无状态的数据, 写入密集型的场景应该使用 volume driver.

volume driver 经常用来实现数据持久化和文件共享功能, 具体有两种存在方式, 分别是:
1. bind mount 方式: 
将host的目录或文件直接mount到容器中, host的目录或文件既可以容器运行之前就已存在的, 也可以是在容器运行之前不存在的. 
如果在docker run 命令中采用了 -v /host/dir_or_file:/container/dir_or_file的形式, 就是bind mount方式, 即指定了host的挂载点的绝对路径. 

2. volume 方式:

是由 Docker 管理, 该volume最终存储到host的 /var/lib/docker/volumes 下. volume 方式还分为 named volume 和 Anonymous volume. 
named volume 有两种创建方法, 
(1) docker run 命令中采用了 -v one_volume_name:/container/dir_or_file , 这里的one_volume_name不是host中的绝对路径, 而是一个名称. 
(2) 通过 docker volume create 创建的, 该命令支持更多的选项, 推荐使用. 
匿名volume方式 是通过 docker run 命令中传入了 -v /container/dir 类型的参数. 


3. bind mount 方式和volume方式的简单对比:
bind mount方式, docker容器直接访问host的目录或文件, 性能是最好的. 但对于该host绝对目录可能会引入权限问题. 如果容器仅需要只读访问权限, 最好是显式设定只读方式. 
对于 volume方式, 如果host中落地目录为空, docker先将容器中的对应目录复制到host下, 然后再进行挂载操作;

bind mount方式,挂载之前没有复制操作,但容器要依赖host主机的一个绝对路径, 使得容器的移植性变差, docker 官方并不推荐这个方法, 而是推荐使用volume。

为容器添加数据卷

// 用户volume方式创建数据卷,并且方式是named,该volume 在 /var/lib/docker/volume/myetc 下. 
docker run -d --name web0 -v myetc:/etc busybox /bin/sh 

// 用匿名的volume方式创建数据卷,该volume在/var/lib/docker/volume父目录下, 具体子目录不确定,
docker run -d --name web1 -v /etc busybox /bin/sh 

// 用bind mount 方式创建数据卷,host上的目录为 /etc2
docker run -d --name web2 -v /etc2:/etc  busybox /bin/sh 

// 挂载多个目录
docker run --name data -v /opt/data1:/var/www/data1 -v /opt/data2:/var/www/data2:ro -t -i docker.io/ubuntu /bin/bash

 定义数据卷容器

#创建一个名 为 dbstore 的数据容器, 设置一个匿名的/dbdata volume. 
docker create -v /dbdata --name dbstore busybox /bin/sh 

#创建一个名为 web3 的应用容器, 将 dbstore 数据容器的volume 挂载过来. 
docker run -d --name web3 --volumes-from dbstore busybox /bin/sh 

#备份数据容器 dbstore 的/dbdata目录到容器到host的host_backup目录下, 最终在host上的文件名为 /host_backup/backup.tar
docker run --rm --volumes-from dbstore  -v /host_backup:/backup busybox tar -cvf /backup/backup.tar /dbdata

#思路: 先新建一个数据卷容器,再建一个新的容器并挂载该数据卷容器,然后再把tar包解包。

#恢复数据容器dbstore 的/dbdata目录, 数据源为host上的文件 /host_backup/backup.tar
docker run --rm --volumes-from dbstore -v /host_backup:/backup busybox /bin/sh -c "cd /dbdata && tar -xvf /backup/backup.tar --strip 1"

参考:https://www.cnblogs.com/kevingrace/p/6238195.html
          https://blog.youkuaiyun.com/hhq12/article/details/81660675 
          https://www.cnblogs.com/harrychinese/p/docker_storage_and_volume.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值