博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mysql relay_log_recovery relay_log_info_repository
阅读量:6148 次
发布时间:2019-06-21

本文共 1263 字,大约阅读时间需要 4 分钟。

relay-log-info

记录SQL线程读取Master binlog的位置,用于Slave 宕机后根据文件中记录的pos点恢复Sql线程

master-info

记录IO线程读取已经读取到的master binlog位置,用于slave宕机后IO线程根据文件中的POS点重新拉取binlog日志

sync_relay_log_info

执行多少个事务后将relay-log-info,sync一下文件刷新到磁盘

sync_master_info

执行多少个事务后将master-info,sync一下文件刷新到磁盘

所以问题来了,如果下面两个sync参数设置较大,当宕机时:

  • sync_master_info较大将导致重复拉取binlog日志
  • sync_relay_log_info较大将导致重复执行binlog日志

那么设置两个参数为1

sync_master_info=1sync_relay_log_info=1

是否解决问题了呢?

那么,请考虑如下场景

正常跑的slave突然掉电,最后一个事务已经commit成功了。但是可能还没有将sync_relay_log_info sync到磁盘上。因为sync文件这个动作不是在事务中,所以不能得到保证。当slave恢复之后,读取relay_log_info文件。会将最后一个事务重新做一遍,导致主从数据不一致

问题的关键在于sync操作不是在事务里,所以mysql提供了两个参数

+---------------------------+-------+| Variable_name             | Value |+---------------------------+-------+| master_info_repository    | TABLE || relay_log_info_repository | TABLE |+---------------------------+-------+

这样记录SQL线程及IO线程的执行情况将记录在表中(slave_relay_log_info,slave_master_info),事务的原子性得到了保证。

这里查看一下,sync_relay_log_info与relay_log_info_repository参数间的关系

这里写图片描述
可以看到当relay_log_info_repository为TABLE时,对于事务来说,sync_relay_log_info参数没有作用了

为了简化设置,这里介绍一个参数

relay_log_recovery

参数含义:当slave重启之后会根据slave_relay_log_info重新创建一个文件,SQL线程会根据这个文件进行恢复复制,IO线程会读取SQL线程的POS点,根据这个POS点向主库申请拉取数据

所以最终只要设置如下两个参数即可

relay_log_info_repository = TABLErelay_log_recovery = ON
你可能感兴趣的文章
企业级负载平衡简介(转)
查看>>
ICCV2017 论文浏览记录
查看>>
科技巨头的交通争夺战
查看>>
当中兴安卓手机遇上农行音频通用K宝 -- 卡在“正在通讯”,一直加载中
查看>>
Shell基础之-正则表达式
查看>>
JavaScript异步之Generator、async、await
查看>>
讲讲吸顶效果与react-sticky
查看>>
c++面向对象的一些问题1 0
查看>>
直播视频流技术名词
查看>>
IOC —— AOP
查看>>
比特币现金将出新招,推动比特币现金使用
查看>>
数据库的这些性能优化,你做了吗?
查看>>
MS SQLSERVER通用存储过程分页
查看>>
60.使用Azure AI 自定义视觉服务实现物品识别Demo
查看>>
Oracle 冷备份
查看>>
jq漂亮实用的select,select选中后,显示对应内容
查看>>
C 函数sscanf()的用法
查看>>
python模块之hashlib: md5和sha算法
查看>>
解决ros建***能登录不能访问内网远程桌面的问题
查看>>
售前工程师的成长---一个老员工的经验之谈
查看>>