docker-【容器数据存储位置分析】以Mysql容器为例

MySQL容器数据存储分析

MySQL容器数据存储分析

Docker中MySQL容器的数据默认存储在容器内部的/var/lib/mysql目录,该目录是MySQL官方镜像预设的数据存储位置。删除容器会导致数据丢失,而仅重启容器不会影响数据。

1.基础了解

docker上我们的mysql容器的数据,默认是存储在mysql容器内部的/var/lib/mysql目录下,但是这样当我们删除mysql容器后重新创建容器,数据就会丢失;

  • 如果只是重启容器(如 docker restart container_name),数据通常不会丢失,因为容器的文件系统仍然存在。
  • 只有在删除容器后再重新创建新容器时,数据才会真正丢失。

其中/var/lib/mysql 是 MySQL 容器内的真实目录( MySQL 官方镜像中预设的数据存储目录)

因此:我们会在宿主机上建立真实的目录(路径):例如:/path/on/host/mysql-data;【即使用宿主机路径绑定挂载容器目录来实现数据持久化】

然后把 /path/on/host/mysql-data 目录挂载到 MySQL 容器内部的 /var/lib/mysql 目录;此时mysql的数据就会存储在我们宿主机的真实目录/path/on/host/mysql-data下了,重启mysql容器,数据就不会丢失;

2.数据持久化方法

通过绑定挂载(Bind Mount)将宿主机目录挂载到容器内的/var/lib/mysql目录,实现数据持久化。例如:

bash 复制代码
docker run -v /path/on/host/mysql-data:/var/lib/mysql mysql

此方法确保数据存储在宿主机,容器删除后数据仍保留。

  • 命令结构
java 复制代码
docker run [OPTIONS] IMAGE [COMMAND] [ARG...]
bash 复制代码
docker run - Docker 命令
-v /path/on/host/mysql-data:/var/lib/mysql - 选项(挂载卷)
mysql - 镜像名称(告诉 Docker 使用哪个镜像来创建容器)
  • 命令含义
bash 复制代码
使用 mysql 镜像
将宿主机的 /path/on/host/mysql-data 目录挂载到容器的 /var/lib/mysql 目录
启动一个基于 mysql 镜像的新容器

3.其他持久化方式使用命名卷的方法

数据卷(Volume)

使用Docker管理的卷,避免直接暴露宿主机路径:

bash 复制代码
docker volume create mysql-data
docker run -v mysql-data:/var/lib/mysql mysql

其实就是使用mysql-data一个命名来替代实际的路径/path/on/host/mysql-data

4.图片示例


相关推荐
程序员老赵1 天前
10 分钟部署 OpenCode:Docker 一键安装,浏览器打开就能用 AI 写代码(附完整命令与排错)
docker·容器·ai编程
WangMingHua1112 天前
LM Studio Docker 部署——本地大模型一键启动
docker
Jim6002 天前
【吃透 MySQL InnoDB连载】第 1 章・解密线上数据库高频故障
mysql
曲幽3 天前
别再用网页翻译看源码了!你的私人翻译神器LibreTranslate,部署避坑指南来了
python·docker·web·pot·translate·libretranslate·arogstranslate
GreatSQL3 天前
gt-checksum v4.0.0 新功能解读系列文章(4):SSL 加密连接——数据校验传输安全再升级
mysql
武子康4 天前
调查研究-183 Apple container:Mac 上用轻量 VM 跑 Linux 容器,Swift 会改写本地容器体验吗?
docker·容器·apple
云技纵横6 天前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
沉默王二6 天前
面试官:RAG 不用向量数据库,用 MySQL 硬扛?我:100 万向量不是很轻松?
mysql·面试·ai编程
小猿姐6 天前
MySQL Top 10 热点问题 AI 运维实战:从内核诊断到云原生运维
mysql·云原生·aiops