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

MySQL主从复制能提升数据安全性、读性能和备份效率。配置过程需要在主库和从库上分别操作,核心是让从库重放主库的二进制日志(binlog)。以下是具体步骤。
主库需启用二进制日志并设置唯一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;
从库也需要设置唯一的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;
启动复制线程:
START SLAVE;
运行以下命令查看从库是否正常同步:
SHOW SLAVE STATUS\G
重点关注两个字段:
如果都是Yes,说明复制正常。若为No,查看Last_Error信息排查问题,常见原因包括网络不通、用户权限不足、pos位置错误等。
确保主从时间一致,避免因时区或时间偏差影响业务。
如果从库已有数据,需先通过备份恢复与主库一致的状态再开启复制。
使用 mysqldump 备份主库时可加 --master-data=1 参数自动记录binlog位置。
生产环境建议开启 relay_log 和 read_only 以增强稳定性。
基本上就这些,配置不复杂但容易忽略细节。
以上就是如何在mysql中配置主从复制的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号