大家好,我是考100分的小小码 ,祝大家学习进步,加薪顺利呀。今天说一说mysql参数max_binlog_cache_size设置不当引发的血案,希望您对编程的造诣更进一步.
日常运维中的坑真是防不胜防,不一小心就遇到别人给你挖的坑。最近又遇到经验不足的DBA不知道从哪拷贝的配置文件(据说是当时参加某培训机构视频培训是资料里的模板,真的是误人子弟呀),其中把max_binlog_cache_size设置的只有2G,而MySQL早已将此参数的默认值调整的很大了(18446744073709547520),实在没想通为何有人会如此修改。
1、 故障描述
收到告警,从库SQL线程停止,查看日志,其中的错误内容如下:
[ERROR] Slave SQL for channel "": Worker 1 failed executing transaction "370e03bf-aa09-11e9-9bd3-e4434b2aa008:248804226" at master log , end_log_pos 2149953254; Could not execute Update_rows event on table dbname.tbname; Multi-statement transaction required more than "max_binlog_cache_size" bytes of storage; increase this mysqld variable and try again, Error_code: 1197; handler error HA_ERR_RBR_LOGGING_FAILED; the event"s master log FIRST, end_log_pos 2149953254, Error_code: 1197
代码100分
提示的很明显,max_binlog_cache_size参数的值小了。
引发此问题的主库执行了几个很大的事务,且从库开启了并行复制,因此需要更大的max_binlog_cache_size来处理innodb事务。
2 、故障处理
处理过程倒是非常简单,该参数可以动态修改,因此直接调整主库及从库的值。因为也确实没必要还原为默认值,毕竟达不到那么大,因此,先将其设置为40GB
代码100分mysql> set global max_binlog_cache_size=40*1024*1024*1024; Query OK, 0 rows affected (0.00 sec)
注意:
1) 主库及从库均进行调整
2) 动态修改后配置文件也需要修改,以免重启后有还原回去了
3) max_binlog_cache_size参数与binlog_cache_size以及Binlog_cache_use等参数有关,因此设置时要根据实际情况调整,千万不可无脑的跟风设置
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/8808.html