MySQL主从复制

目录

一:MySQL主从复制原理

1:MySQL支持的复制类型

[(1) 基于语句的复制(SBR)](#(1) 基于语句的复制(SBR))

[(2) 基于行的复制(RBR)](#(2) 基于行的复制(RBR))

[(3) 混合模式复制(MBR)](#(3) 混合模式复制(MBR))

2:复制的工作过程

[(1) 主服务器操作](#(1) 主服务器操作)

[(2) 从服务器操作](#(2) 从服务器操作)

[(3) 详细流程](#(3) 详细流程)

二:案例环境

[1. 服务器规划](#1. 服务器规划)

[2. 网络要求](#2. 网络要求)

三:案例实施

1:配置master主服务器

(1)修改MySQL配置文件(my.cnf)

(2)重启MySQL服务

(3)创建复制专用用户

(4)查看主服务器状态

2:配置slave从服务器

(1)修改MySQL配置文件(my.cnf)

(2)重启MySQL服务

(3)登录MySQL,配置同步

(4)启动同步

(5)查看slave状态,确保一下两个值为YES

3:验证主从复制效果

(1)在主服务器创建测试数据库

(2)在从服务器验证


一:MySQL主从复制原理

1:MySQL支持的复制类型

(1) 基于语句的复制(SBR)

  • 主服务器记录执行的SQL语句

  • 从服务器重放这些SQL语句

  • 优点:日志量小

  • 缺点:某些函数(如UUID(), NOW())可能导致不一致

(2) 基于行的复制(RBR)

  • 主服务器记录行级别的变更

  • 从服务器直接应用这些行变更

  • 优点:数据一致性高

  • 缺点:日志量大

(3) 混合模式复制(MBR)

  • 默认使用基于语句的复制

  • 在特定情况下自动切换到基于行的复制

  • 结合了两者的优点

2:复制的工作过程

(1) 主服务器操作

  1. 二进制日志记录:主服务器将所有数据更改操作(DDL和DML)记录到二进制日志(binlog)中

  2. 日志刷新:通过sync_binlog参数控制日志刷新到磁盘的频率

(2) 从服务器操作

  1. I/O线程

    • 连接到主服务器

    • 请求主服务器发送binlog中的更新

    • 接收binlog并写入从服务器的中继日志(relay log)

  2. SQL线程

    • 读取中继日志中的事件

    • 重放这些事件,更新从服务器数据

(3) 详细流程

  1. 主库开启binlog,从库通过change master命令配置连接主库的信息

  2. 从库启动复制后,I/O线程与主库建立连接

  3. 主库验证从库连接后,开始发送binlog事件

  4. 从库I/O线程接收事件并写入relay log

  5. 从库SQL线程读取relay log并应用这些事件

  6. 从库记录已经处理的事件位置(relay-log.info)

二:案例环境

1. 服务器规划

  • 操作系统: openEuler

  • MySQL版本: 5.7 或 8.0 (建议使用相同版本)

|--------|-----------------|----------------|--------------|
| 主机 | 操作系统 | ip地址 | 应用 |
| Master | openEuler 24.03 | 192.168.10.101 | Mysql-server |
| Slave1 | openEuler 24.03 | 192.168.10.102 | Mysql-server |
| Slave2 | openEuler 24.03 | 192.168.10.103 | Mysql-server |
| mycat | openEuler 24.03 | 192.168.10.104 | mycat2 |
| 客户端 | openEuler 24.03 | 192.168.10.105 | mysql |
[案例环境]

2. 网络要求

  • 确保主从服务器之间网络互通

  • 开放MySQL默认端口3306

  • 关闭防火墙或设置相应规则

三:案例实施

1:配置master主服务器

(1)修改MySQL配置文件(my.cnf)

cpp 复制代码
[client]
socket=/usr/local/mysql/data/mysql.sock 
[mysqld] 
server-id=1
socket=/usr/local/mysql/data/mysql.sock
bind-address = 0.0.0.0
skip-name-resolve
port = 3306
basedir=/usr/local/mysql
datadir=/usr/local/mysql/data
max_connections=2048
character-set-server=utf8
default-storage-engine=INNODB
lower_case_table_names=1
max_allowed_packet=16M

[mysqld_safe]
log-error=/usr/local/mysql/data/error.log
pid-file=/var/run/mariadb/mariadb.pid

(2)重启MySQL服务

cpp 复制代码
systemctl restart mysqld

(3)创建复制专用用户

cpp 复制代码
mysql -uroot -ppwd123
create user 'myslave'@'%' identified by '123456';
grant replication slave on *.* to 'myslave'@'%';
alter user 'myslave'@'%' identified with mysql_native_password by '123456';

(4)查看主服务器状态

cpp 复制代码
flush privileges;

show master status;
#记录输出中的File和Position值,例如:
+------------------+----------+--------------+------------------+-------------------+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+------------------+----------+--------------+------------------+-------------------+
| mysql-bin.000001 |      745 | test_db      | mysql            |                   |
+------------------+----------+--------------+------------------+-------------------+

2:配置slave从服务器

在Slave1,Slave2服务器上面分别执行下面步骤:

(1)修改MySQL配置文件(my.cnf)

cpp 复制代码
[client]
socket=/usr/local/mysql/data/mysql.sock 
[mysqld] 
server-id=2
socket=/usr/local/mysql/data/mysql.sock
bind-address = 0.0.0.0
skip-name-resolve
port = 3306
basedir=/usr/local/mysql
datadir=/usr/local/mysql/data
max_connections=2048
character-set-server=utf8
default-storage-engine=INNODB
lower_case_table_names=1
max_allowed_packet=16M

[mysqld_safe]
log-error=/usr/local/mysql/data/error.log
pid-file=/var/run/mariadb/mariadb.pid

(2)重启MySQL服务

cpp 复制代码
systemctl restart mysqld

(3)登录MySQL,配置同步

cpp 复制代码
mysql -uroot -ppwd123
change master to master_host='192.168.10.201',master_user='myslave',master_password='123456',master_log_file='mysql-bin.00001',master_log_pos=157;

(4)启动同步

cpp 复制代码
start slave;

(5)查看slave状态,确保一下两个值为YES

cpp 复制代码
start slave status\G;

3:验证主从复制效果

(1)在主服务器创建测试数据库

cpp 复制代码
CREATE DATABASE test_db;
USE test_db;
CREATE TABLE test_table (id INT AUTO_INCREMENT PRIMARY KEY, name VARCHAR(50));
INSERT INTO test_table (name) VALUES ('测试数据1'), ('测试数据2');

(2)在从服务器验证

cpp 复制代码
USE test_db;
SELECT * FROM test_table;
相关推荐
巨龙之路1 小时前
什么是时序数据库?
数据库·时序数据库
蔡蓝1 小时前
binlog日志以及MySQL的数据同步
数据库·mysql
是店小二呀2 小时前
【金仓数据库征文】金融行业中的国产化数据库替代应用实践
数据库·金融·数据库平替用金仓·金仓数据库2025征文
炒空心菜菜2 小时前
SparkSQL 连接 MySQL 并添加新数据:实战指南
大数据·开发语言·数据库·后端·mysql·spark
专注于大数据技术栈2 小时前
Mac上安装Mysql的详细步骤及配置
mysql
多多*3 小时前
算法竞赛相关 Java 二分模版
java·开发语言·数据结构·数据库·sql·算法·oracle
爱喝酸奶的桃酥3 小时前
MYSQL数据库集群高可用和数据监控平台
java·数据库·mysql
数据库幼崽3 小时前
MySQL 8.0 OCP 1Z0-908 61-70题
数据库·mysql·ocp
进击的CJR3 小时前
MySQL 8.0 OCP 英文题库解析(四)
mysql
神仙别闹3 小时前
基于C#+MySQL实现(WinForm)企业设备使用信息管理系统
开发语言·mysql·c#