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;
相关推荐
柏油34 分钟前
可视化 MySQL binlog 监听方案
数据库·后端·mysql
k↑1 小时前
微服务之注册中心与ShardingSphere关于分库分表的那些事
数据库·微服务·架构·shardingsphere
柏油2 小时前
MySQL 字符集 utf8 与 utf8mb4
数据库·后端·mysql
我科绝伦(Huanhuan Zhou)2 小时前
异构数据库兼容力测评:KingbaseES 与 MySQL 的语法・功能・性能全场景验证解析
数据库·mysql
Apple_羊先森2 小时前
Oracle数据库操作深入研究:备份、数据删除与性能优化
数据库·oracle·性能优化
BTU_YC2 小时前
docker compose部署mysql
mysql·adb·docker
麦麦大数据4 小时前
F004 新闻可视化系统爬虫更新数据+ flask + mysql架构
爬虫·mysql·flask·可视化·新闻
xiao-xiang11 小时前
redis-保姆级配置详解
数据库·redis
白鹭13 小时前
MySQL(多表查询练习)
数据库·mysql