使用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 是 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说明:
如果你希望直接控制数据存放路径,可以使用宿主机的一个目录进行挂载。
先在宿主机创建目录:
mkdir -p /mydata/mysql/data运行容器时挂载该目录:
本书是全面讲述PHP与MySQL的经典之作,书中不但全面介绍了两种技术的核心特性,还讲解了如何高效地结合这两种技术构建健壮的数据驱动的应用程序。本书涵盖了两种技术新版本中出现的最新特性,书中大量实际的示例和深入的分析均来自于作者在这方面多年的专业经验,可用于解决开发者在实际中所面临的各种挑战。
466
注意:
如果你使用 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/mysqlvolumes: mysql-data:
启动服务:
docker compose up -d数据会自动保存在名为 mysql-data 的卷中,下次启动仍可使用。
基本上就这些。只要把 /var/lib/mysql 挂载到持久化存储位置,就能保证 MySQL 数据不随容器消失而丢失。Docker Volume 更推荐,管理方便且与宿主机解耦。如果需要备份或迁移,直接操作对应目录或卷即可。
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号