MySQL主从同步需主库启用binlog并创建repl用户,记录File和Position;从库设唯一server-id,用CHANGE MASTER TO指定主库信息及起始点,START SLAVE后验证Slave_IO_Running和Slave_SQL_Running均为Yes。

一主一从 MySQL 主从架构的核心是让一台 MySQL 服务器(主库)将数据变更通过二进制日志(binlog)实时同步给另一台服务器(从库),从而实现读写分离、备份容灾或负载分担。配置本身不复杂,但关键步骤必须严格按顺序执行,尤其注意 server-id 唯一性、网络连通性、用户权限和 binlog 格式。
主库配置:开启 binlog 并创建复制用户
主库必须启用 binlog,并设置唯一 server-id;同时创建专用于复制的账号,授予 REPLICATION SLAVE 权限。
server-id = 1 log-bin = mysql-bin binlog-format = ROW expire_logs_days = 7
- 重启 MySQL 服务生效:systemctl restart mysqld(或 mysql.server restart)
- 登录 MySQL,创建复制用户(例如用户名 repl,密码 Repl@123):
CREATE USER 'repl'@'%' IDENTIFIED BY 'Repl@123'; GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%'; FLUSH PRIVILEGES;
- 记录当前 binlog 文件名和位置,后续从库需从此处开始同步:
SHOW MASTER STATUS;
输出类似:File: mysql-bin.000001, Position: 154 —— 记下这两个值,配置从库时要用。
从库配置:设置唯一 server-id 并启动复制
从库不能与主库或其他从库的 server-id 冲突,且需关闭 binlog(可选,若需级联复制则开启)。
- 编辑从库配置文件,在 [mysqld] 段下设置:
server-id = 2 # log-bin = mysql-bin # 可注释掉,除非要做级联复制 read_only = ON
- 重启从库 MySQL
- 使用 CHANGE MASTER TO 命令指定主库连接信息和起始同步点(用上一步记下的 File 和 Position):
CHANGE MASTER TO MASTER_HOST='192.168.1.10', # 主库 IP MASTER_USER='repl', MASTER_PASSWORD='Repl@123', MASTER_PORT=3306, MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=154;
- 启动复制线程:
START SLAVE;
验证主从是否正常运行
仅执行 START SLAVE 不代表成功,必须检查关键状态字段。
Difeye是一款超轻量级PHP框架,主要特点有: Difeye是一款超轻量级PHP框架,主要特点有: ◆数据库连接做自动主从读写分离配置,适合单机和分布式站点部署; ◆支持Smarty模板机制,可灵活配置第三方缓存组件; ◆完全分离页面和动作,仿C#页面加载自动执行Page_Load入口函数; ◆支持mysql,mongodb等第三方数据库模块,支持读写分离,分布式部署; ◆增加后台管理开发示例
- 在从库执行:
SHOW SLAVE STATUS\G
重点确认以下两项均为 Yes:
- Slave_IO_Running: Yes(IO 线程已连接主库并拉取日志)
- Slave_SQL_Running: Yes(SQL 线程已解析并执行中继日志)
若任一为 No,查看 Seconds_Behind_Master(延迟秒数)和 LastError 字段排查问题,常见原因包括网络不通、复制用户权限不足、主从时间不同步、表结构不一致等。
简单测试同步效果
在主库建库、建表、插入数据,观察是否自动出现在从库。
- 主库执行:
CREATE DATABASE testdb; USE testdb; CREATE TABLE t1(id INT PRIMARY KEY); INSERT INTO t1 VALUES (1),(2);
- 稍等片刻,从库执行:
SHOW DATABASES LIKE 'testdb'; SELECT * FROM testdb.t1;
应能查到相同结果。此时主从同步已基本就绪。









