从零搭建高可用的 MySQL 主从复制架构(基于 Linux 实战指南)

背景

在生产环境中,单点 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 集群高可用方案


为大规模业务系统提供更稳定可靠的数据库支撑。

原文链接:,转发请注明来源!