一个参数引起的mysql从库宕机血案

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了一个参数引起的mysql从库宕机血案相关的知识,希望对你有一定的参考价值。

原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://suifu.blog.51cto.com/9167728/1859252

技术分享

一个参数引起的mysql从库宕机血案

 

Part1:max_binlog_cache_size

max_binlog_cache_size 表示的是binlog 能够使用的最大cache 内存大小

当我们执行多语句事务的时候 所有session的使用的内存超过max_binlog_cache_size的值时

就会报错:“Multi-statement transaction required more than ‘max_binlog_cache_size‘ bytes ofstorage”

 

技术分享

 

 

Part2:为什么它能引起宕机

 

Warning:警告1

max_binlog_cache_size在主从设置不一致的情况下,主库参数值大于从库参数值,在主库进行大事务操作时,主库顺利进行,从库因max_binlog_cache_size值低于该事物所需,从库会抛出“Multi-statement transaction required more than ‘max_binlog_cache_size‘ bytes ofstorage”错误号为1197。


Warning:警告2

max_binlog_cache_size在主从参数设置一样的情况下,主库执行大事务操作,如主库提示需提高该参数以顺利执行SQL,但DBA只调整了主库的max_binlog_cache_size而忘记调整从库的max_binlog_cache_size,则同样从库会爆出1197错误,导致主从不同步。

 

 

Part3:该设置值为多少

具体值设置为多少,不能纸上谈兵,还需要看公司的具体业务,这里除了不设置该值使用默认值(默认值很大)以外,个人推荐值为4G,基本已经足够应付大部分场合,但无论是否指定该值,在对大表进行操作时,都需注意上述的警告内容,避免该值设置不合理引起从库无法执行报1197的问题。具体命令如下:

set global max_binlog_cache_size =4294967296;

技术分享

 

 

——总结——

该值为动态参数,可以随时利用上述命令进行调整,所以别忘记将该参数加入到my.cnf中以防止重启数据库后失效。由于笔者的水平有限,编写时间也很仓促,文中难免会出现一些错误或者不准确的地方,不妥之处恳请读者批评指正。

本文出自 “贺磊” 博客,请务必保留此出处http://suifu.blog.51cto.com/9167728/1859252

以上是关于一个参数引起的mysql从库宕机血案的主要内容,如果未能解决你的问题,请参考以下文章

企业场景一主多从宕机从库宕机解决

一例mysql主从数据库,从库宕机后无法启动的解决方案

mysql主库宕机,如何最快处理?

6-MYSQL主从同步(DBA)配置

《叶问》34期,延迟从库加上MASTER_DELAY,主库宕机后如何快速恢复服务

mysql主从切换