百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

Docker 数据持久化最佳实践:Volume 使用全指南

ztj100 2025-07-21 19:11 4 浏览 0 评论

你是不是也经常在使用 Docker 的时候,遇到“数据持久化”相关的困惑?容器删了,数据也跟着没了?今天就带你深入了解 Docker 的 Volume机制,搞懂什么是 Volume、怎么使用、存储在哪,以及如何实现多个容器共享存储!


一、什么是 Docker Volume?

Docker 的 Volume(卷)是官方推荐的数据持久化方案,用来将容器中的数据独立存储在宿主机上。与容器生命周期解耦,删除容器不会影响数据,非常适合用于数据库、日志等场景。

简单理解就是:容器内的数据 -> Volume -> 宿主机目录


二、Volume 的使用场景

  • 容器内服务需要持久化数据,比如 MySQL、Redis、PostgreSQL
  • 多个容器之间需要共享数据
  • 防止重要数据在容器销毁时丢失
  • 容器频繁更新、迁移,但数据需要保留

三、Volume 怎么使用?

1. 创建 Volume

docker volume create mydata

查看:

docker volume ls

2. 使用 Volume 运行容器

docker run -d \
  --name mysql \
  -v mydata:/var/lib/mysql \
  mysql:5.7

这条命令把宿主机上的 mydata 卷挂载到了容器中的 /var/lib/mysql,MySQL 的数据就存储在这个卷里。

3. 查看卷挂载路径

docker volume inspect mydata

输出中 Mountpoint 字段会告诉你这个卷实际挂载到了宿主机的哪个路径,例如:

"Mountpoint": "/var/lib/docker/volumes/mydata/_data"

也就是说,你的数据其实是存在宿主机这个目录下的。


四、Docker Volume 存储在哪?

默认情况下,Docker 会将 Volume 存储在:

/var/lib/docker/volumes/卷名/_data/

你也可以用第三方存储驱动(如 NFS、GlusterFS、Ceph 等)把 Volume 存储到远程服务器或分布式存储系统。


五、如何共享 Volume?

方式1:多个容器挂载同一个 Volume

docker run -d --name container1 -v mydata:/app/data busybox sleep 3600
docker run -d --name container2 -v mydata:/app/data busybox sleep 3600

两个容器就可以共享 /app/data 目录下的内容了。

方式2:使用--volumes-from继承挂载

docker run -d --name container1 -v /data busybox
docker run -d --name container2 --volumes-from container1 busybox

适合某些场景下的依赖继承,比如日志采集、配置共享等。



六、Volume 的清理

删除未使用的卷

docker volume prune

删除指定卷

docker volume rm mydata

注意:如果卷还在使用中,删除会失败。


七、补充:Volume vs Bind Mount

特性

Volume(推荐)

Bind Mount(绑定挂载)

安全性

高,Docker 自主管理

较低,容易暴露宿主机结构

跨平台支持

备份和迁移

简单

需要自行管理

场景

数据持久化、共享数据

本地开发、配置文件挂载


总结一下

Docker Volume 是实现容器数据持久化和共享的关键工具。掌握 Volume,可以让你:

  • 保证数据不随容器销毁而丢失
  • 实现多个容器的数据共享
  • 更安全、便捷地管理容器生命周期中的数据

别再让数据随风而去了,赶紧用 Volume 把数据稳稳托住吧!

相关推荐

新手学Docker:挂载卷Volumes(docker挂载nfs卷)

默认情况下,在容器内创建的文件,都会保存在容器基于镜像之上的一个可读写层。但是,这一层是依赖于容器而存在的,当容器不存在时,这些数据也就不存在了。而且这些数据紧紧的耦合在容器内部,很难将这些数据导出。...

Docker命令最全详解(39个最常用命令)

Docker是云原生的核心,也是大厂的必备技能,下面我就全面来详解Docker核心命令@mikechen本文作者:陈睿|mikechen文章来源:mikechen.cc一、Docker基本命令...

松勤软件测试:详解Docker,如何用portainer管理Docker容器

镜像管理搜索镜像dockersearch镜像名称拉取镜像dockerpullname[:tag]列出镜像dockerimages删除镜像dockerrmiimage名称或id删除...

【Docker 新手入门指南】第十四章:Docker常用命令

以下Docker常用命令大全,涵盖容器、镜像、网络、数据卷及系统管理等核心操作,结合分类与示例助你快速掌握:一、容器生命周期管理...

Docker 一键清盘术,释放磁盘空间不求人

在日常开发和运维中,Docker容器化让我们的工作更高效,但不知不觉中,磁盘空间却被镜像、容器和卷悄悄吃掉。今天教你一套干净利落的Docker磁盘清理攻略,让你轻松腾出宝贵空间!一、快速查看磁盘...

第六节 Docker 容器核心操作与实践指南

一、镜像与容器的本质关系(一)镜像(Image)的核心特性静态模板:包含应用运行所需的所有依赖(系统库、运行时、配置文件等)不可变性:镜像构建完成后内容不可修改,确保环境一致性...

别再去找Docker命令了,你要的常用的全都在这

Docker常用命令集合给大家介绍一些常用的Docker命令,对你有帮助的同学建议收藏作为一个查询手册哦。Docker容器的一些命令按功能分类大致如下:Docker环境信息info、versio...

Docker 数据持久化最佳实践:Volume 使用全指南

你是不是也经常在使用Docker的时候,遇到“数据持久化”相关的困惑?容器删了,数据也跟着没了?今天就带你深入了解Docker的Volume机制,搞懂什么是Volume、怎么使用、存储在...

【Docker 新手入门指南】第十五章:常见故障排除

一、前期准备:收集关键信息在排查问题前,建议先获取以下系统数据,便于精准定位故障:...

Docker网络与iptables实战指南:从原理到安全加固

一、Docker网络核心原理:容器与iptables的“共生关系”Docker容器的网络能力依赖于Linux内核的两大核心技术:虚拟网络设备(vethpair、网桥)和iptables规则链。以默认...

别再docker exec了!盘点进入容器排错的5种“更优雅”姿势

一、dockerattach:直接“附身”容器的原始方法当容器日志疯狂刷屏时,dockerattach就像直接跳进正在行驶的汽车——能看到仪表盘数据,但方向盘不在你手上。这种直接附加到容器主进程的...

云计算核心技术Docker教程:Docker数据卷的使用

在生产环境中使用Docker,要想实现数据的持久化(所谓Docker的数据持久化即数据不随着Container的结束而结束)或者需要在多个容器之间进行数据共享,需要将数据从宿主机挂载到容器中,这就会...

【开发技术】Mybatis中进行多表关联查询?性能是不是会变好呢?

Mybatis是一种基于Java的持久层框架,能够帮助我们操作数据库。在Mybatis中,进行多表关联的整合查询,需要使用嵌套查询或者使用ResultMap进行映射。下面,我们将从这两个方面来介绍多表...

Mybatis 批量更新数据 Mysql批量更新数据

通常如果需要一次更新多条数据有两个方式,(1)在业务代码中循环遍历逐条更新。(2)一次性更新所有数据1批量更新相同的值不同的条件...

Mybatis 如何批量删除数据(mybatis批量merge)

Mybatis如何批量删除数据本期以最常用的根据id批量删除数据为例:接口设计1:List类型单参数IntegerdeleteByIds(List<Integer>ids);...

取消回复欢迎 发表评论: