首页 > 代码库 > MySQL二进制日志格式对复制的影响
MySQL二进制日志格式对复制的影响
复制的分类
基于SQL语句的复制 - SBR
主库二进制日志格式使用STATEMENT
在MySQL 5.1之前仅存在SBR模式, 又称之为逻辑复制.
主库记录CUD操作的SQL语句, 从库会读取并重放.
-
优点
-
生成的日志量少, 节约网络传输IO
-
当主从的列的顺序不一致时, SBR依然可以正常工作.
如对大表进行结构修改时, 可以先修改从库, 然后再进行主从切换.
-
-
缺点
- 对不确定性函数无法保证主从数据的一致
- 对于procedure, trigger, function有可能在主从上表现不一致(SBR BUG)
- 主库上要锁定多少行, 从库上也需要所以多少行, 所以相对于ROW复制时从库上需要更多的行锁
基于行的复制 - RBR
主库二进制日志格式使用ROW
-
优点
-
对不确定性函数友好, 如UUID()
-
减少从库上数据库锁的使用
insert into t_order_cnt(timestr, total, amount) select date(order_date), count(1), sum(amout) from t_order group by date(order_date);
- 1
- 2
- 3
- 1
- 2
- 3
上面的SQL在主库执行时会对
t_order
进行锁表操作, 对于STATEMENT的复制从库上也会对同样的表进行锁定, 但是基于ROW的复制仅需增加t_order
对应的行的数据即可.
-
-
缺点
- 要求主从数据库的表的结构一致, 否则可能会中断复制
- 无法在从库上激活trigger
Github
基于Docker Compose构建的MySQL MHA集群
MySQL二进制日志格式对复制的影响
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。