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

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

ztj100 2025-07-21 19:11 34 浏览 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 把数据稳稳托住吧!

相关推荐

Linux集群自动化监控系统Zabbix集群搭建到实战

自动化监控系统...

systemd是什么如何使用_systemd/system

systemd是什么如何使用简介Systemd是一个在现代Linux发行版中广泛使用的系统和服务管理器。它负责启动系统并管理系统中运行的服务和进程。使用管理服务systemd可以用来启动、停止、...

Linux服务器日常巡检脚本分享_linux服务器监控脚本

Linux系统日常巡检脚本,巡检内容包含了,磁盘,...

7,MySQL管理员用户管理_mysql 管理员用户

一、首次设置密码1.初始化时设置(推荐)mysqld--initialize--user=mysql--datadir=/data/3306/data--basedir=/usr/local...

Python数据库编程教程:第 1 章 数据库基础与 Python 连接入门

1.1数据库的核心概念在开始Python数据库编程之前,我们需要先理解几个核心概念。数据库(Database)是按照数据结构来组织、存储和管理数据的仓库,它就像一个电子化的文件柜,能让我们高效...

Linux自定义开机自启动服务脚本_linux添加开机自启动脚本

设置WGCloud开机自动启动服务init.d目录下新建脚本在/etc/rc.d/init.d新建启动脚本wgcloudstart.sh,内容如下...

linux系统启动流程和服务管理,带你进去系统的世界

Linux启动流程Rhel6启动过程:开机自检bios-->MBR引导-->GRUB菜单-->加载内核-->init进程初始化Rhel7启动过程:开机自检BIOS-->M...

CentOS7系统如何修改主机名_centos更改主机名称

请关注本头条号,每天坚持更新原创干货技术文章。如需学习视频,请在微信搜索公众号“智传网优”直接开始自助视频学习1.前言本文将讲解CentOS7系统如何修改主机名。...

前端工程师需要熟悉的Linux服务器(SSH 终端操作)指令

在Linux服务器管理中,SSH(SecureShell)是远程操作的核心工具。以下是SSH终端操作的常用命令和技巧,涵盖连接、文件操作、系统管理等场景:一、SSH连接服务器1.基本连接...

Linux开机自启服务完全指南:3步搞定系统服务管理器配置

为什么需要配置开机自启?想象一下:电商服务器重启后,MySQL和Nginx没自动启动,整个网站瘫痪!这就是为什么开机自启是Linux运维的必备技能。自启服务能确保核心程序在系统启动时自动运行,避免人工...

Kubernetes 高可用(HA)集群部署指南

Kubernetes高可用(HA)集群部署指南本指南涵盖从概念理解、架构选择,到kubeadm高可用部署、生产优化、监控备份和运维的全流程,适用于希望搭建稳定、生产级Kubernetes集群...

Linux项目开发,你必须了解Systemd服务!

1.Systemd简介...

Linux系统systemd服务管理工具使用技巧

简介:在Linux系统里,systemd就像是所有进程的“源头”,它可是系统中PID值为1的进程哟。systemd其实是一堆工具的组合,它的作用可不止是启动操作系统这么简单,像后台服务...

Red Hat Enterprise Linux 10 安装 Kubernetes (K8s) 集群及高级管理

一、前言...

Linux下NetworkManager和network的和平共处

简介我们在使用CentoOS系统时偶尔会遇到配置都正确但network启动不了的问题,这问题经常是由NetworkManager引起的,关闭NetworkManage并取消开机启动network就能正...

取消回复欢迎 发表评论: