MySQL主从复制通过配置主库启用binlog并创建复制账号,从库设置唯一server-id后连接主库重放binlog实现数据同步,需确保网络通畅、权限正确及pos位置准确,检查Slave_IO_Running和Slave_SQL_Running均为Yes以确认正常复制。

MySQL主从复制能提升数据安全性、读性能和备份效率。配置过程需要在主库和从库上分别操作,核心是让从库重放主库的二进制日志(binlog)。以下是具体步骤。
1. 配置主库(Master)
主库需启用二进制日志并设置唯一server-id。
修改主库配置文件 my.cnf 或 my.ini:[mysqld]
server-id = 1
log-bin = mysql-bin
binlog-format = ROW
重启MySQL服务使配置生效:
systemctl restart mysql
登录MySQL创建用于复制的账号:
CREATE USER 'repl'@'%' IDENTIFIED BY 'password';
GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%';
FLUSH PRIVILEGES;
查看主库当前binlog状态,记录File和Position:
SHOW MASTER STATUS;
2. 配置从库(Slave)
从库也需要设置唯一的server-id,但不能与主库相同。
修改从库配置文件:[mysqld]
server-id = 2
重启从库MySQL服务:
systemctl restart mysql
进入MySQL,执行CHANGE MASTER命令连接主库:
CHANGE MASTER TO
MASTER_HOST='主库IP',
MASTER_USER='repl',
MASTER_PASSWORD='password',
MASTER_LOG_FILE='mysql-bin.000001',
MASTER_LOG_POS=154;
启动复制线程:
第一步】:将安装包中所有的文件夹和文件用ftp工具以二进制方式上传至服务器空间;(如果您不知如何设置ftp工具的二进制方式,可以查看:(http://www.shopex.cn/support/qa/setup.help.717.html)【第二步】:在浏览器中输入 http://您的商店域名/install 进行安装界面进行安装即可。【第二步】:登录后台,工具箱里恢复数据管理后台是url/sho
START SLAVE;
3. 检查复制状态
运行以下命令查看从库是否正常同步:
SHOW SLAVE STATUS\G
重点关注两个字段:
- Slave_IO_Running: Yes
- Slave_SQL_Running: Yes
如果都是Yes,说明复制正常。若为No,查看Last_Error信息排查问题,常见原因包括网络不通、用户权限不足、pos位置错误等。
4. 注意事项与建议
确保主从时间一致,避免因时区或时间偏差影响业务。
如果从库已有数据,需先通过备份恢复与主库一致的状态再开启复制。
使用 mysqldump 备份主库时可加 --master-data=1 参数自动记录binlog位置。
生产环境建议开启 relay_log 和 read_only 以增强稳定性。
基本上就这些,配置不复杂但容易忽略细节。









