网站首页 > 技术教程 正文
背景
在生产环境中,单点 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 集群高可用方案
为大规模业务系统提供更稳定可靠的数据库支撑。
猜你喜欢
- 2025-07-08 MySQL用命令行复制表的方法(mysql怎么复制语句)
- 2025-07-08 从理论到实战,彻底搞懂MySQL主从复制原理
- 2025-07-08 电脑操作手机的神器——虫洞,还有更好的免费协同
- 2025-07-08 Python文件复制方法详解(python复制文件夹下所有文件及子文件夹)
- 2025-07-08 Linux scp远程复制命令使用整理(linux远程拷贝命令)
- 2025-07-08 Linux文件复制命令精要指南:cp与scp详解
- 2025-07-08 如何设置sap的快捷剪切粘贴(sap添加快捷命令)
- 2025-07-08 Linux最常用命令及快捷键整理(linux快捷键大全)
- 2025-07-08 用Python复制文件的9个方法(python复制内容)
- 2025-07-08 windows通过cmd 如何从linux复制文件到本地桌面
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- 下划线是什么 (87)
- 精美网站 (58)
- qq登录界面 (90)
- nginx 命令 (82)
- nginx .http (73)
- nginx lua (70)
- nginx 重定向 (68)
- Nginx超时 (65)
- nginx 监控 (57)
- odbc (59)
- rar密码破解工具 (62)
- annotation (71)
- 红黑树 (57)
- 智力题 (62)
- php空间申请 (61)
- 按键精灵 注册码 (69)
- 软件测试报告 (59)
- ntcreatefile (64)
- 闪动文字 (56)
- guid (66)
- abap (63)
- mpeg 2 (65)
- column (63)
- dreamweaver教程 (57)
- excel行列转换 (56)
本文暂时没有评论,来添加一个吧(●'◡'●)