一主一从 MySQL 主从架构的核心是让一台 MySQL 服务器(主库)将数据变更通过二进制日志(binlog)实时同步给另一台服务器(从库),从而实现读写分离、备份容灾或负载分担。配置本身不复杂,但关键步骤必须严格按顺序执行,尤其注意 server-id 唯一性、网络连通性、用户权限和 binlog 格式。
主库配置:开启 binlog 并创建复制用户
主库必须启用 binlog,并设置唯一 server-id;同时创建专用于复制的账号,授予 REPLICATION SLAVE 权限。
编辑主库配置文件(如 /etc/my.cnf 或 /etc/mysql/mysql.conf.d/mysqld.cnf),在 [mysqld] 段下添加: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 不代表成功,必须检查关键状态字段。
在从库执行: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;
应能查到相同结果。此时主从同步已基本就绪。
