博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
slave复制中断 ,别滥用SQL_SLAVE_SKIP_COUNTER
阅读量:5820 次
发布时间:2019-06-18

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

来源:http://blog.chinaunix.net/uid-26364035-id-3588217.html

【问题背景】

 1、从库的复制出现中断,如主键冲突;对应的表或者库不存在;基于row复制时,操作的行不存在;
常常大家会通过使用set global SQL_SLAVE_SKIP_COUNTER=n 来跳过导致复制错误的SQL.
 2、 使用sql_slave_skip_counter跳过,每一次跳过为一个Binlog event group, 也就相当于一个事务。
所以当一个事务中有两个SQL, 第一个SQL导致主从复制中断,然后我们直接使用SQL_SLAVE_SKIP_COUNTER=1跳过错了
其实第二个SQL也不会在slave中执行了,如果第二个SQL影响100行,那么主从就有100行数据不一致了。
所以 我们在跳过之前,一定要看一下,当前binlog event group到底是什么?
下列是延迟从库,因为表不存在,导到主从复制中断的例 
1、查看show slave status的状态
mysql> Show slave status\G
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 10.4.12.33
          --------------------省略-----------------------------
              Master_Log_File: mysql-bin.000123
          Read_Master_Log_Pos: 334510571
              
 Relay_Log_File: mysql-relay-bin.000184
               
 
Relay_Log_Pos: 534584783
        Relay_Master_Log_File: mysql-bin.000112
             Slave_IO_Running: Yes
            Slave_SQL_Running: No
                   Last_Errno: 1146
                  
 Last_Error: Error 'Table 'dbxxx
.table_
general' doesn't exist' on query. Default database: 'dbxxx
'. Query: 'truncate table 
table_
general
'
                 Skip_Counter: 0
          Exec_Master_Log_Pos: 534584637
2、根据slave status中的
Relay_Log_File
Relay_Log_Pos两个值 ,先查看当前被中断的binlog event group操作是什么?
查看的命令:
   show relaylog events in "Relay_Log_File" from Relay_Log_Pos limit n;
  eg.
    mysql> relaylog events in 'mysql-relay-bin.ooo1o4' from 23484738 limit 10;
就可以明显看到,是由于truncate table db58_user_credit_general时, 表db58_user_credit_general不存在, 所以整个binlog group就这一个语句。
处理的方式以下两种都可以:
    1)可以直接使用set global SQL_SLAVE_SKIP_COUNTER=1跳过此binlog event group
    2) set sql_log_bin=OFF;  create table db58_user_credit_general(id int); set sql_log_bin=ON;

转载地址:http://zszdx.baihongyu.com/

你可能感兴趣的文章
C语言小题2
查看>>
配置华为防火墙ssh ASDM
查看>>
c3p0配置文件
查看>>
浅谈Java设计模式之工厂模式
查看>>
自动化运维工具 Ansible 的详细部署
查看>>
[笔记]在IDEA中使用Tomcat远程调试WEB项目时的相关配置
查看>>
Nginx支持Socket转发过程详解
查看>>
18种常见数据挖掘算法
查看>>
kubernetes1.13.1部署ingress-nginx并配置https转发dashboard
查看>>
“***不是内部或外部命令”问题解决方法
查看>>
Web缓存(Varnish方案)
查看>>
SQL慢查询在Greenplum/Deepgreen中的定位方法
查看>>
关于这个博客分类的说明
查看>>
整体改革理论(简介)
查看>>
Asp.Net WebApi2+Unity+EF6.0整合
查看>>
uc_user_synlogin返回为空不能同步
查看>>
ios开发备忘录一
查看>>
第15课:RDD创建内幕彻底解密
查看>>
spring 监听器 IntrospectorCleanupListener简介
查看>>
Eclipse CDT配置
查看>>