美文网首页
Binary Log基于ROW模式下的从库复制延时问题

Binary Log基于ROW模式下的从库复制延时问题

作者: __Jo | 来源:发表于2019-05-17 17:55 被阅读0次

关键字

innodb version 5.7 replication delay

参考&引用

问题描述

业务表没有主键(唯一键), 主库执行了一条大量删除的DELETE语句导致,导致Slave延时。

表结构设计

由于binlog 是基于Row模式的,主库的一条大量删除DELETE语句会产生大量binlog日志。这种情况下,从库 SQL Thread 在重放Relay Log时,由于表结构不存在唯一键(没有好的索引),导致所有重放都是一次全表扫描。

从设计上讲,所有表都应该有唯一主键,至少有自增主键(最好强制要求所有表均有自增主键)。这次的问题主要是项目引用的开源的项目(XXX), 表结构设计的非常有问题。

问题解决

表结构补上唯一索引(或加上自增主键)是最好的方式。 但是如果因为一些原因,无法改表结构的情况,可以临时通过调整slave_rows_search_algorithms参数为INDEX_SCAN,HASH_SCAN(默认值INDEX_SCAN,TABLE_SCAN),改变从库复制表搜索算法,来加速复制。

--动态参数
set global slave_rows_search_algorithms = 'INDEX_SCAN,HASH_SCAN';

官方文档说明:

* The default value is INDEX_SCAN,TABLE_SCAN, which means that all searches that can use indexes do use them, and searches without any indexes use table scans.

* To use hashing for any searches that do not use a primary or unique key, set INDEX_SCAN,HASH_SCAN. Specifying INDEX_SCAN,HASH_SCAN has the same effect as specifying INDEX_SCAN,TABLE_SCAN,HASH_SCAN, which is allowed.

对照测试实验

同一从库上堆积一个大事务情况下,相同的Exec_Master_Log_Pos,相同时间内,先后观察innodb undo 数相差10倍+(数值仅参考)。

INDEX_SCAN,TABLE_SCAN INDEX_SCAN,HASH_SCAN

相关文章

  • Binary Log基于ROW模式下的从库复制延时问题

    关键字 innodb version 5.7 replication delay 参考&引用 MySQL Docs...

  • Mysql 复制架构

    Mysql 复制架构 数据库复制的其实就是数据的同步,Mysql数据库基于binary log日志进行数据增量同步...

  • mysql binlog基本原理

    基于binlog的主从复制 Mysql 5.0以后,支持通过binary log(二进制日志)以支持主从复制。复制...

  • MySQL复制3--配置Master

    为了让master能够启用基于binary log file position的复制,需要在master开启bin...

  • 九,主从复制高级进阶

    1,延时从库 介绍 配置 延时从库处理逻辑故障 故障演练 主库: 从库 恢复到从库 2,过滤复制 例子 3,GTI...

  • 主从复制基础

    主从复制 SQL故障 从库延时 MTS

  • Mysql - 主从复制

    主从复制过程 主库把数据更改记录到二进制日志(Binary Log)中; 从库将主库上的二进制日志复制到自己的中继...

  • Mysql集群-v1

    Mysql 内存+后台线程 主从复制 1. Master 库中,数据变更时,写入binary Log。 2. Sl...

  • 主从复制高级

    主从复制高级 延时从库 故障恢复 半同步复制 主从复制过滤 gtid的复制 故障:

  • MySQL - 主从复制为什么会出现延迟

    MySQL默认的主从复制是基于binary log来实现的. 当有数据写入时 通过IO线程 将日志同步至Slave...

网友评论

      本文标题:Binary Log基于ROW模式下的从库复制延时问题

      本文链接:https://www.haomeiwen.com/subject/kmaoaqtx.html