如何在docker中持久化mysql数据

使用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 中运行 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 挂载本地目录

如果你希望直接控制数据存放路径,可以使用宿主机的一个目录进行挂载。

先在宿主机创建目录:

如何在docker中持久化mysql数据

如知AI笔记

如知笔记——支持markdown的在线笔记,支持ai智能写作、AI搜索,支持DeepseekR1满血大模型

如何在docker中持久化mysql数据27

查看详情 如何在docker中持久化mysql数据

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 更推荐,管理方便且与宿主机解耦。如果需要备份或迁移,直接操作对应目录或卷即可。

上一篇
下一篇
text=ZqhQzanResources