背景
在生产环境中,单点 MySQL 数据库容易成为性能瓶颈或单点故障源。搭建 MySQL 主从复制架构,可以实现读写分离、高可用,提升系统的整体稳定性与扩展性。
二、架构设计
- 主库(Master):负责处理写请求
- 从库(Slave):负责处理读请求
- 同步方式:异步复制(Asynchronous Replication)
后续可根据需求扩展为半同步(Semi-Sync)或 MGR(Group Replication)。
三、环境准备
- 系统环境:CentOS 8 / Rocky Linux 8
- MySQL 版本:MySQL 8.0
- 主服务器 IP:192.168.1.10
- 从服务器 IP:192.168.1.20
两台服务器均已关闭防火墙并设置 SELinux 为 permissive 模式。
四、主服务器配置(Master)
1. 安装 MySQL
dnf install -y @mysql
systemctl enable mysqld
systemctl start mysqld
2. 配置 MySQL 主库参数
编辑 /etc/my.cnf 文件:
[mysqld]
server-id=1
log-bin=mysql-bin
binlog-do-db=testdb
- server-id:每台服务器唯一 ID
- log-bin:启用二进制日志,必要条件
- binlog-do-db:指定需要复制的数据库
重启服务:
systemctl restart mysqld
3. 创建复制用户
CREATE USER 'repl'@'%' IDENTIFIED BY 'repl_password';
GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%';
FLUSH PRIVILEGES;
五、从服务器配置(Slave)
1. 安装 MySQL
dnf install -y @mysql
systemctl enable mysqld
systemctl start mysqld
2. 配置从库参数
编辑 /etc/my.cnf 文件:
[mysqld]
server-id=2
relay-log=relay-log
read-only=1
重启服务:
systemctl restart mysqld
六、配置主从同步
1. 在主库查看当前二进制日志信息
SHOW MASTER STATUS;
记录 File 和 Position。
2. 在从库设置主服务器信息
CHANGE MASTER TO
MASTER_HOST='192.168.1.10',
MASTER_USER='repl',
MASTER_PASSWORD='repl_password',
MASTER_LOG_FILE='mysql-bin.000001',
MASTER_LOG_POS=154;
3. 启动同步
START SLAVE;
查看同步状态:
SHOW SLAVE STATUS\G
确认 Slave_IO_Running: Yes 和 Slave_SQL_Running: Yes。
七、测试主从同步
在主库创建新表或插入数据,从库应能实时同步数据:
CREATE DATABASE testdb;
USE testdb;
CREATE TABLE t1 (id INT PRIMARY KEY, name VARCHAR(50));
INSERT INTO t1 VALUES (1, 'hello replication');
在从库查询:
SELECT * FROM testdb.t1;
能看到同步的数据即为成功。
八、总结
本篇实战搭建了一个基础的 MySQL 主从复制环境,具备可读写分离能力。
后续可以在此基础上继续扩展:
- 半同步复制
- 多源复制
- MySQL Router
- MGR 集群高可用方案
为大规模业务系统提供更稳定可靠的数据库支撑。