使用docker Volume或Bind Mount可实现mysql数据持久化。1. 创建命名卷:docker volume create mysql-data,并挂载至容器的/var/lib/mysql目录,确保数据独立于容器生命周期;2. 使用Bind Mount将宿主机目录(如/mydata/mysql/data)挂载到容器,便于直接管理数据路径;3. 通过Docker Compose定义服务与卷,在docker-compose.yml中配置volumes字段,启动时自动绑定。推荐优先使用Docker Volume,由Docker管理存储位置,解耦宿主机,提升可移植性。只要数据目录挂载到持久化存储,即可避免容器删除导致的数据丢失。

在 Docker 中运行 MySQL 时,如果不做特殊处理,容器一旦被删除,里面的数据也会随之丢失。为了确保数据安全和可复用,必须实现数据的持久化。最常用的方式是使用 Docker 的 数据卷(Volume) 或 绑定挂载(Bind Mount) 将 MySQL 的数据目录保存到宿主机上。
使用 Docker Volume 持久化 MySQL 数据
Docker Volume 是 Docker 管理的持久化存储方式,推荐用于数据库类应用。
创建一个命名的数据卷:
docker volume create mysql-data
启动 MySQL 容器并挂载该卷:
docker run -d –name mysql-container -e MYSQL_ROOT_PASSword=your_password -v mysql-data:/var/lib/mysql -p 3306:3306 mysql:8.0
说明:
- -v mysql-data:/var/lib/mysql:将名为 mysql-data 的卷挂载到容器内的 MySQL 数据目录。
- 即使容器被删除,只要不手动删除该卷,数据依然保留。
- Docker 负责管理卷的存储位置(通常在 /var/lib/docker/volumes/ 下)。
使用 Bind Mount 挂载本地目录
如果你希望直接控制数据存放路径,可以使用宿主机的一个目录进行挂载。
先在宿主机创建目录:
mkdir -p /mydata/mysql/data
运行容器时挂载该目录:
docker run -d –name mysql-container -e MYSQL_ROOT_PASSWORD=your_password -v /mydata/mysql/data:/var/lib/mysql -p 3306:3306 mysql:8.0
注意:
- 确保宿主机目录有正确的读写权限,MySQL 进程需要能访问。
- 第一次启动会初始化数据,后续重启或新建容器挂载同一目录即可继续使用原有数据。
通过 Docker Compose 实现持久化
如果你使用 Docker Compose,配置更清晰易管理。
编写 docker-compose.yml 文件:
version: ‘3.8’ services: mysql: image: mysql:8.0 environment: MYSQL_ROOT_PASSWORD: your_password ports: – “3306:3306” volumes: – mysql-data:/var/lib/mysql
volumes: mysql-data:
启动服务:
docker compose up -d
数据会自动保存在名为 mysql-data 的卷中,下次启动仍可使用。
基本上就这些。只要把 /var/lib/mysql 挂载到持久化存储位置,就能保证 MySQL 数据不随容器消失而丢失。Docker Volume 更推荐,管理方便且与宿主机解耦。如果需要备份或迁移,直接操作对应目录或卷即可。


