温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

参数binlog_row_image设置MINIMAL,你今天被坑了吗?

发布时间:2020-06-05 06:07:05 来源:网络 阅读:8678 作者:hcymysql 栏目:MySQL数据库

今天网友"芬达"跟我讨论一个参数binlog_row_image,在什么场景下设置为MINIMAL,我觉得这个案例很有意义,尤其是在生产环境中,要慎重设置这个参数。


首先这个MINIMAL,只会在binlog里记录被影响的行,而不能像默认的FULL一样,记录完整的变更前和变更后的所有记录,这里就会产生一个问题,数据被误更改,无法用mysqlbinlog等工具闪回,另外大数据那边用canal抽binlog,会造成数据不准确等一系列问题。


下面通过模拟实验,看看binlog里记录的内容。


表结构如下:

参数binlog_row_image设置MINIMAL,你今天被坑了吗?


里面的数据:

参数binlog_row_image设置MINIMAL,你今天被坑了吗?


此时,执行一条update变更操作:

参数binlog_row_image设置MINIMAL,你今天被坑了吗?


马上看下binlog里面记录的内容:

参数binlog_row_image设置MINIMAL,你今天被坑了吗?

注意看红色框部分的内容,变更前的完整原始数据并没有被记录,固无法闪回。


虽然MINIMAL可以减少binlog的文件大小(binlog_format = ROW),降低磁盘IO,但从数据安全角度来看,这将是危险的!


这里感谢网友"芬达"提供素材。



向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI