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.图片示例

