Docker 数据卷与存储机制(持久化与共享实战)

前言

一、为什么需要数据卷

二、数据卷的类型

三、匿名卷(自动创建)

四、具名卷(命名卷)

五、绑定挂载(Bind Mount)

5.1 权限控制

5.2 容器到宿主机复制数据

六、数据卷容器(Volumes From)

七、Volume 常用命令

八、Docker Compose 中的数据卷

九、持久化数据库案例

9.1 MySQL 数据卷示例

9.2 Redis 数据卷示例

十、数据卷备份与恢复

10.1 备份卷

10.2 恢复卷

十一、容器数据持久化设计建议

十二、卷清理与维护

十三、总结

前言

在前几篇中,我们学习了容器的运行、网络和资源控制。 但是——容器是临时性的:当你删除一个容器时,它内部的文件和数据也会随之消失。

在实际生产环境中,我们需要让:

  • 应用数据 能够长期保存;

  • 配置文件 能够方便修改;

  • 容器之间 能共享数据;

这些需求的核心就是:👉 Docker 数据卷(Volume)机制


一、为什么需要数据卷

默认情况下,Docker 容器的数据保存在容器层(UnionFS)中:

  • 当容器删除时,数据随之销毁。

  • 容器与宿主机之间的数据无法直接交互。

解决方案: 使用 数据卷(Volume),即宿主机与容器之间的共享目录。

💡 一句话理解: 数据卷是“容器的硬盘映射”,用来实现数据持久化与共享


二、数据卷的类型

类型挂载方式特点
匿名卷-v /data仅容器内部路径,Docker 自动分配宿主机目录
具名卷-v volume_name:/data有自定义名称,方便复用
绑定挂载(Bind Mount)-v /host/path:/container/path宿主机与容器共享目录
只读挂载-v /data:/data:ro宿主机数据只读不可写

三、匿名卷(自动创建)

docker run -d -v /data nginx

查看卷:

docker volume ls

查看卷详情:

docker volume inspect <volume_name>

输出示例:

"Mountpoint": "/var/lib/docker/volumes/1a2b3c4d/_data"

特点: Docker 自动分配目录,适用于临时或测试环境。


四、具名卷(命名卷)

docker run -d --name web1 -v nginx_data:/usr/share/nginx/html nginx

查看卷:

docker volume ls

输出:

DRIVER    VOLUME NAME
local     nginx_data

宿主机路径:

/var/lib/docker/volumes/nginx_data/_data

💡 适合场景: 生产环境中应用数据或配置文件的长期存储。


五、绑定挂载(Bind Mount)

直接将宿主机目录挂载到容器中。

docker run -d \
  --name web2 \
  -v /opt/wwwroot:/usr/share/nginx/html \
  -p 8080:80 \
  nginx

测试修改内容:

echo "Hello Docker Volume" > /opt/wwwroot/index.html

浏览器访问:

http://宿主机IP:8080

✅ 页面会即时更新,不需要重启容器。


5.1 权限控制

只读挂载:

docker run -d -v /opt/config:/etc/nginx/conf.d:ro nginx

:ro 表示容器内部无法修改该目录内容。 适合挂载配置文件、防止误改。


5.2 容器到宿主机复制数据

从容器中拷贝文件到宿主机:

docker cp web1:/usr/share/nginx/html/index.html /tmp/

反向拷贝:

docker cp /tmp/test.conf web1:/etc/nginx/conf.d/

六、数据卷容器(Volumes From)

多个容器之间共享数据卷。

创建共享卷容器:

docker run -d --name dbdata -v /data/mysql mysql:5.7

使用相同卷的容器:

docker run -d --name db1 --volumes-from dbdata mysql:5.7
docker run -d --name db2 --volumes-from dbdata mysql:5.7

此时 db1db2 均共享 /data/mysql 数据。

💡 即使删除 dbdata 容器,卷也不会被删除,数据仍然保留。


七、Volume 常用命令

操作命令说明
查看所有卷docker volume ls显示卷列表
查看卷信息docker volume inspect 卷名查看路径与挂载点
删除卷docker volume rm 卷名删除指定卷
删除所有未使用卷docker volume prune清理无主卷
创建卷docker volume create 卷名手动创建卷

八、Docker Compose 中的数据卷

Compose 支持更简洁的卷定义方式。

version: "3"
services:
  nginx:
    image: nginx
    ports:
      - "8080:80"
    volumes:
      - ./www:/usr/share/nginx/html
      - nginx_conf:/etc/nginx/conf.d
volumes:
  nginx_conf:

说明:

  • ./www:/usr/share/nginx/html → 绑定挂载(宿主机目录)

  • nginx_conf → 命名卷(自动管理)

查看卷列表:

docker volume ls

九、持久化数据库案例

9.1 MySQL 数据卷示例

docker run -d \
  --name mysql \
  -e MYSQL_ROOT_PASSWORD=123456 \
  -v /opt/mysql_data:/var/lib/mysql \
  mysql:5.7

所有数据库文件都会存放在宿主机 /opt/mysql_data


9.2 Redis 数据卷示例

docker run -d \
  --name redis \
  -v /opt/redis_data:/data \
  redis:latest

容器删除后重新启动,数据仍会保留。


十、数据卷备份与恢复

10.1 备份卷

docker run --rm \
  -v nginx_data:/data \
  -v $(pwd):/backup \
  busybox tar cvf /backup/backup.tar /data

10.2 恢复卷

docker run --rm \
  -v nginx_data:/data \
  -v $(pwd):/backup \
  busybox tar xvf /backup/backup.tar -C /

💡 busybox 容器是轻量级工具镜像,非常适合卷备份操作。


十一、容器数据持久化设计建议

设计原则说明
应用与数据分离应用逻辑放在镜像中,数据放在卷中
使用具名卷管理数据避免路径混乱,方便迁移
数据库一定要持久化防止容器删除导致数据丢失
重要配置挂载为只读防止意外修改生产配置
备份卷数据使用 tar + volume 定期备份

十二、卷清理与维护

查看未使用卷:

docker volume ls -f dangling=true

清理未使用卷:

docker volume prune

清理所有无用资源(包括卷、镜像、容器):

docker system prune -a

⚠️ 注意:清理操作不可逆,请谨慎执行。


十三、总结

通过本篇学习,你应掌握:

✅ 区分匿名卷、具名卷与绑定挂载

✅ 熟悉 -v 参数语法与权限设置

✅ 使用 --volumes-from 实现容器间共享数据

✅ 数据卷的备份与恢复方法

✅ Docker Compose 中的数据卷定义

✅ 构建安全、高可维护的持久化存储方案

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值