news 2026/4/17 15:41:51

Docker Compose 实战:5 分钟搭一套 MySQL 主从集群

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Docker Compose 实战:5 分钟搭一套 MySQL 主从集群

在真实生产环境中,数据库绝不能只有一份。 哪怕你还没上 K8s,也应该至少有:

1 主 + 1 从 = 数据安全 + 读写分离

而 Docker Compose,正是最快落地 MySQL 主从的利器。


一、整体架构

我们要搭建的是经典 MySQL 主从架构:

二、准备目录结构

mysql-cluster/ ├── docker-compose.yml ├── master/ │ └── my.cnf └── slave/ └── my.cnf

三、Master 配置

master/my.cnf

[mysqld] server-id=1 log-bin=mysql-bin binlog-format=ROW

四、Slave 配置

slave/my.cnf

[mysqld] server-id=2 relay-log=mysql-relay-bin read-only=1

五、docker-compose.yml

version: "3.8" services: mysql-master: image:mysql:8.0 container_name:mysql-master restart:always environment: MYSQL_ROOT_PASSWORD:root volumes: -./master/my.cnf:/etc/mysql/conf.d/my.cnf -master-data:/var/lib/mysql ports: -"3306:3306" mysql-slave: image:mysql:8.0 container_name:mysql-slave restart:always environment: MYSQL_ROOT_PASSWORD:root volumes: -./slave/my.cnf:/etc/mysql/conf.d/my.cnf -slave-data:/var/lib/mysql ports: -"3307:3306" depends_on: -mysql-master volumes: master-data: slave-data:

六、一条命令启动

docker compose up -d 查看: docker compose ps

七、在 Master 上创建复制账号

​ ​ docker exec -it mysql-master mysql -uroot -proot CREATE USER 'repl'@'%' IDENTIFIED BY 'repl123'; GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%'; FLUSH PRIVILEGES; 查看 binlog: SHOW MASTER STATUS; 记住: File: mysql-bin.000001 Position: 1234 ​ ​

八、在 Slave 上配置同步

docker exec -it mysql-slave mysql -uroot -proot CHANGE MASTER TO MASTER_HOST='mysql-master', MASTER_USER='repl', MASTER_PASSWORD='repl123', MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=1234; START SLAVE; 检查状态: SHOW SLAVE STATUS\G; 看到: Slave_IO_Running: Yes Slave_SQL_Running: Yes 说明主从同步成功 🎉

九、测试同步

在 master: CREATE DATABASE testdb; USE testdb; CREATE TABLE t1(id INT); INSERT INTO t1 VALUES(1); 在 slave: SELECT * FROM testdb.t1; 能看到 1,说明复制已生效。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 8:20:19

字节跳动AHN:革新长文本建模的高效记忆网络

字节跳动AHN:革新长文本建模的高效记忆网络 【免费下载链接】AHN-DN-for-Qwen-2.5-Instruct-3B 项目地址: https://ai.gitcode.com/hf_mirrors/ByteDance-Seed/AHN-DN-for-Qwen-2.5-Instruct-3B 导语:字节跳动推出的Artificial Hippocampus Netw…

作者头像 李华
网站建设 2026/4/18 3:18:28

Gemma 3超轻量270M:QAT技术打造低耗AI新体验

Gemma 3超轻量270M:QAT技术打造低耗AI新体验 【免费下载链接】gemma-3-270m-it-qat-bnb-4bit 项目地址: https://ai.gitcode.com/hf_mirrors/unsloth/gemma-3-270m-it-qat-bnb-4bit 导语:Google DeepMind推出的Gemma 3系列最新270M参数模型&…

作者头像 李华
网站建设 2026/4/18 8:30:41

Zen Browser终极指南:快速掌握高效隐私浏览新体验

Zen Browser终极指南:快速掌握高效隐私浏览新体验 【免费下载链接】desktop 🌀 Experience tranquillity while browsing the web without people tracking you! 项目地址: https://gitcode.com/GitHub_Trending/desktop70/desktop 还在为浏览器卡…

作者头像 李华
网站建设 2026/4/18 12:54:25

Glyph功能测评:图像化文本处理,这创意太绝了

Glyph功能测评:图像化文本处理,这创意太绝了 1. 引言:当文本变成图像,上下文还能这么玩? 你有没有遇到过这样的问题:想让大模型读一篇万字长文做摘要,结果它“记不住”前面的内容?…

作者头像 李华
网站建设 2026/4/18 10:53:51

性能翻倍:RexUniNLU指代消解优化技巧分享

性能翻倍:RexUniNLU指代消解优化技巧分享 1. 引言:为什么指代消解如此关键? 在自然语言理解任务中,我们常常遇到这样的句子:“李明告诉王芳她通过了面试。”——这里的“她”到底是谁?是李明还是王芳&…

作者头像 李华
网站建设 2026/4/17 16:19:58

Qwen3-1.7B快速体验指南:5步完成环境搭建

Qwen3-1.7B快速体验指南:5步完成环境搭建 你是不是也想第一时间上手体验阿里巴巴最新发布的Qwen3系列大模型?尤其是轻量级但性能出色的 Qwen3-1.7B,非常适合本地部署、快速测试和轻量级应用开发。本文将带你从零开始,只需5个步骤…

作者头像 李华