如何在mysql中配置主从复制

来源:这里教程网 时间:2026-02-28 20:12:50 作者:

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;

启动复制线程:

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 以增强稳定性。

基本上就这些,配置不复杂但容易忽略细节。

相关推荐