MySQL的半同步模式

MySQL的主从架构采用的是异步模式

master更新完成后直接发送二进制日志到slave,但是slaves是否真正保存了数据master端不会检测,master端直接保存二进制日志到磁盘,当master端到slave端的网络出现问题时或者master端直接挂掉,二进制日志可能根本没有到达slave,master出现问题slave端接管master,这个过程中数据就丢失了,这样的问题出现就无法达到数据的强一致性,导致数据丢失。

这时候我们可以使用半同步模式:

1.用户线程写入完成后master中的dump会把日志推送到slave端

2.slave中的io线程接收后保存到relaylog中继日志

3.保存完成后slave向master端返回ack

4.在未接受到slave的ack时master端时不做提交的,一直处于等待当收到ack后提交到存储引擎

5.在5.6版本中用到的时after_commit模式,after_commit模式时先提交在等待ack返回后输出ok

gtid模式:

在master端的写入时多用户读写,在slave端的复制时单线程日志回放,所以slave端一定会延迟与

master端,这种延迟在slave端的延迟可能会不一致,当master挂掉后slave接管,一般会挑选一个和master延迟日志最接近的充当新的master,那么为接管master的主机继续充当slave角色并会指向到新的master上,作为其slave这时候按照之前的配置我们需要知道新的master上的pos的id,但是我们无法确定新的master和slave之间差多少。

设置gtid:

#在master端和slave端开启gtid模式

在MySQL的配置文件中写入gtid_mode=ON

enforce-gtid-consistency=ON

然后停止slave端

开启slave端的gtid

CHANGE MASTER TO MASTER_HOST='1', MASTER_USER='2',

MASTER_PASSWORD='3', MASTER_AUTO_POSITION=4;

然后开启start slave

show slave status\G;

查看

启用半同步模式

在master端配置启用半同步模式

在配置文件中写入:

rpl_semi_sync_master_enabled=1#开启半同步功能

然后安装半同步插件

INSTALL PLUGIN rpl_semi_sync_master SONAME 'semisync_master.so';

查看插件情况

SELECT PLUGIN_NAME, PLUGIN_STATUS

-> FROM INFORMATION_SCHEMA.PLUGINS

-> WHERE PLUGIN_NAME LIKE '%semi%';

打开半同步功能

SET GLOBAL rpl_semi_sync_master_enabled = 1;

#查看半同步功能状态

然后再slave中开启半同步功能

rpl_semi_sync_master_enabled=1 #开启半同步功能

也是安装插件,打开半同步功能,查看插件和功能是否开启

然后没有重启io线程,半同步生效

STOP SLAVE IO_THREAD;START SLAVE IO_THREAD;#重启io线程,半同步才能生效

然后查看状态。

最后测试

在master中写入数据

相关推荐
科技小花3 小时前
全球化深水区,数据治理成为企业出海 “核心竞争力”
大数据·数据库·人工智能·数据治理·数据中台·全球化
X56614 小时前
如何在 Laravel 中正确保存嵌套动态表单数据(主服务与子服务)
jvm·数据库·python
虹科网络安全6 小时前
艾体宝干货|数据复制详解:类型、原理与适用场景
java·开发语言·数据库
2301_771717216 小时前
解决mysql报错:1406, Data too long for column
android·数据库·mysql
绘梨衣5476 小时前
Docker+FastAPI+MySQL 项目部署报错汇总
mysql·docker·fastapi
qq_435287926 小时前
第9章 夸父逐日与后羿射日:死循环与进程终止?十个太阳同时值班的并行冲突
java·开发语言·git·死循环·进程终止·并行冲突·夸父逐日
小江的记录本6 小时前
【Kafka核心】架构模型:Producer、Broker、Consumer、Consumer Group、Topic、Partition、Replica
java·数据库·分布式·后端·搜索引擎·架构·kafka
dvjr cloi6 小时前
MySQL Workbench菜单汉化为中文
android·数据库·mysql
dFObBIMmai7 小时前
MySQL主从同步中大事务导致的延迟_如何拆分大事务优化同步
jvm·数据库·python
szccyw07 小时前
mysql如何限制特定存储过程执行权限_MySQL存储过程安全访问
jvm·数据库·python