【MySQL故障处理】 Seconds_Behind_Master= NULL Error_code: 1197
admin
2023-05-18 14:22:06
0


将处理主从故障的过程记录在此:

  • 故障1,Error_code: 1197 (max_binlog_cache_size)

数据库版本:5.7.9

报错信息:

[ERROR] Slave SQL for channel '': 
Worker 1 failed executing transaction 'bea4612c-4828-11e7-90b3-a0423f31cad6:716212' at master log mysql.135371, end_log_pos 103016490; 
Could not execute Write_rows event on table ******; 
Multi-statement transaction required more than 'max_binlog_cache_size' bytes of storage; 
increase this mysqld variable and try again, Error_code: 1197; 
Writing one row to the row-based binary log failed, Error_code: 1534; 
handler error HA_ERR_RBR_LOGGING_FAILED; 
the event's master log FIRST, end_log_pos 103016490, Error_code: 1197

处理过程:

根据报错信息,知道是max_binlog_cache_size小了,

解决办法:临时增加该值后restart slave即可以继续复制线程。

stop slave;
set global max_binlog_cache_size= 201326592;
start slave;

关于max_binlog_cache_size请看这里:

如果一个事务需要多于设置值的内存,就会报上面的错。最小4096字节,最大支持4GB,因为binlog位置点最大4GB,支持动态修改

解决了问题,继续查找发生问题的原因,生产环境中的该参数设置为64M,当一个事务影响的数据量超过该值时,即会报错。

查看主库中日志的具体内容:

数据库日志格式为mixed,文件中记录的是row格式,使用下面命令查看

/bin/mysqlbinlog   -vv --base64-output=decode-rows mysql.135371 | more
精简后的内容:
#  13:43:59 server id *******  end_log_pos 10538 CRC32  Write_rows: table id 2776
# at 10538                                          
#  13:43:59 server id *******  end_log_pos 18175 CRC32  Write_rows: table id 2776
# at 18175                                         
#  13:43:59 server id *******  end_log_pos 25789 CRC32  Write_rows: table id 2776
# at 25789                                           
#  13:43:59 server id *******  end_log_pos 33424 CRC32  Write_rows: table id 2776
# at 33424                                            
#  13:43:59 server id *******  end_log_pos 40961 CRC32  Write_rows: table id 2776
# at 40961                                           
#  13:43:59 server id *******  end_log_pos 48553 CRC32  Write_rows: table id 2776
# at 48553                                          
#  13:43:59 server id *******  end_log_pos 56126 CRC32  Write_rows: table id 2776
# at 56126                                          
#  13:43:59 server id *******  end_log_pos 63671 CRC32  Write_rows: table id 2776
# at 63671                                          
#  13:43:59 server id *******  end_log_pos 71205 CRC32  Write_rows: table id 2776
# at 71205                                           
#  13:43:59 server id *******  end_log_pos 78753 CRC32  Write_rows: table id 2776
# at 78753                                           
#  13:43:59 server id *******  end_log_pos 86322 CRC32  Write_rows: table id 2776
# at 86322                                           
#  13:43:59 server id *******  end_log_pos 93925 CRC32  Write_rows: table id 2776

不出意外,执行的sql为

 insert into table1 select * from table2 where time > '2016-10-01'

形式的多语句事务,查看binlog文件的大小,最大的超过了200M(max_binlog_size设置为50M)。

因此是大事务造成的,大事务还容易造成主从延时的问题,推荐将大事务拆分为小事务执行

107M  14:07 mysql.135380
101M  14:08 mysql.135381
112M  14:08 mysql.135382
110M  14:09 mysql.135383
124M  14:09 mysql.135384
 31M  14:10 mysql.135385
226M  14:10 mysql.135386
120M  14:12 mysql.135387
111M  14:13 mysql.135388
102M  14:14 mysql.135389
...
126M  14:16 mysql.135394
...
118M  14:23 mysql.135404
...
110M  14:28 mysql.135409
 63M  14:29 mysql.135410
104M  14:29 mysql.135411
 281  14:30 mysql.135412
115M  14:30 mysql.135413
112M  14:30 mysql.135414
127M  14:30 mysql.135415
119M  14:31 mysql.135416
 85M  14:32 mysql.135417
 60M  14:32 mysql.135418
151M  14:33 mysql.135419
  • 故障2,Errno: 1872,Error: Slave failed to initialize relay log info structure from the repository

    数据库在 'in place' 升级之后报出该错误,重启主从后问题解决

    查看问题有人说原因是从库信息变化导致的,解决方法可以reset slave,重新change master。


欢迎批评指正

相关内容

热门资讯

自动空调调到多少度合适 冬天,调成30度比较合适的。夏天的时候,空调设置的温度应该比室外温度低3到4度,一般来说,26度是比...
空调制热多少度合适 空调制热多少度合适?从人体舒适方面来考虑,冬季室内温度最好控制在18—20度之间。在这个温度下人是感...
电视机运行内存多大合适 电视机运行内存多大合适:4k电视的运行内存在2GB及以上最好。如今,Android 5.0以上的系统...
iphone13电量 演示机型信息: 品牌型号:iPhone13 系统版本:IOS16.1 iphone13电量最高百分之...
noritz能率热水器维修电话 热水器在我们的日常生活中扮演着重要的角色,为我们提供温暖舒适的热水。然而,由于长时间使用或其他原因,...
嘉善双飞取得金属带换向输送装置... 国家知识产权局信息显示,嘉善双飞润滑材料有限公司取得一项名为“金属带换向输送装置”的专利,授权公告号...
“千里之行,始于足下”,哈萨克... 据凤凰卫视报道,哈萨克斯坦首都阿斯塔纳首条无人驾驶轻轨列车5月16日正式投入运营,多家中企参与建造和...
三星电子会长李在镕公开道歉,呼... 据CCTV国际时讯报道,5月16日,三星电子会长李在镕就公司“内部问题”公开道歉。 当地时间202...
“福特”号航母返回母港:曾在伊... 据凤凰卫视报道,美国航空母舰“福特”号在结束了为期11个月的部署后,5月16日返回弗吉尼亚州诺福克海...
CERN的奠基之路和日本团队的... 缪子作为第二代轻子,是1936年美国物理学家卡尔·安德森(Carl D. Anderson,因发现正...