使用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
运行容器时挂载该目录:
PHP5 和 MySQL 圣经
本书是全面讲述PHP与MySQL的经典之作,书中不但全面介绍了两种技术的核心特性,还讲解了如何高效地结合这两种技术构建健壮的数据驱动的应用程序。本书涵盖了两种技术新版本中出现的最新特性,书中大量实际的示例和深入的分析均来自于作者在这方面多年的专业经验,可用于解决开发者在实际中所面临的各种挑战。
466 查看详情
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 更推荐,管理方便且与宿主机解耦。如果需要备份或迁移,直接操作对应目录或卷即可。
以上就是如何在docker中持久化mysql数据的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/715635.html
微信扫一扫
支付宝扫一扫