• binlog格式设置


    格式1: STATEMENT模式 (基于SQL语句的复制(statement-based replication, SBR))

    每一条会修改数据的sql语句会记录到binlog中。这是默认的binlog格式。

    SBR 的优点:

    • 历史悠久,技术成熟
    • 不需要记录每一行的变化,减少了binlog日志量,文件较小
    • binlog中包含了所有数据库更改信息,可以据此来审核数据库的安全等情况
    • binlog可以用于实时的还原,而不仅仅用于复制
    • 主从版本可以不一样,从服务器版本可以比主服务器版本高

    SBR 的缺点:

    • 使用以下函数的语句也无法被复制:LOAD_FILE()、UUID()、USER()、SYSDATE()(除非启动时启用了 --sysdate-is-now 选项)

    这也是系统不允许我们创建函数的原因,从服务器执行时间函数,复制的数据会不一样

    • INSERT … SELECT 会产生比 RBR 更多的行级锁
    • 复制需要进行全表扫描(WHERE 语句中没有使用到索引)的 UPDATE 时,需要比 RBR 请求更多的行级锁
    • 对于有 AUTO_INCREMENT 字段的 InnoDB表而言,INSERT 语句会阻塞其他 INSERT 语句
    • 对于一些复杂的语句,在从服务器上的耗资源情况会更严重,而 RBR 模式下,只会对那个发生变化的记录产生影响
    • 执行复杂语句如果出错的话,会消耗更多资源
    • 数据表必须几乎和主服务器保持一致才行,否则可能会导致复制出错

    ROW模式(基于行的复制(row-based replication, RBR))

    不记录每条sql语句的上下文信息,仅记录哪条数据被修改了,修改成什么样了。就是你插入5条数据,RBR会记录五条数据,而SBR只会记录一条插入数据的sql

    RBR 的优点:

    • 任何情况都可以被复制,这对复制来说是最安全可靠的。(比如:不会出现某些特定情况下的存储过程、function、trigger的调用和触发无法被正确复制的问题)
    • 多数情况下,从服务器上的表如果有主键的话,复制就会快了很多
    • 复制以下几种语句时的行锁更少:INSERT … SELECT、包含 AUTO_INCREMENT 字段的 INSERT、没有附带条件或者并没有修改很多记录的 UPDATE 或 DELETE 语句执行 INSERT,UPDATE,DELETE 语句时锁更少
    • 从服务器上采用多线程来执行复制成为可能

    RBR 的缺点:

    • binlog 大了很多
    • 复杂的回滚时 binlog 中会包含大量的数据
    • 主服务器上执行 UPDATE 语句时,所有发生变化的记录都会写到 binlog 中,而 SBR 只会写一次,这会导致频繁发生 binlog 的并发写问题
    • 无法从 binlog 中看到都复制了些什么语句

    MIXED模式(混合模式复制(mixed-based replication, MBR))

    在Mixed模式下,一般的语句修改使用statment格式保存binlog。如一些函数:statement无法完成主从复制的操作,则采用row格式保存binlog。MySQL会根据执行的每一条具体的sql语句来区分对待记录的日志形式,也就是在Statement和Row之间选择一种。

  • 相关阅读:
    java-拓展
    arcmap-arcgis-模型构建器
    13-ES5和ES6基础
    杂牌行车记录仪mp4恢复案例
    压力测试-JMeter安装、入门、结果分析
    微信小程序游戏开发│智力测试游戏——button版
    uniapp 分享到朋友圈
    数据分析——A/B测试二:优惠券AB测试项目
    redis高可用——主从复制、哨兵模式、cluster集群
    一个简单的Python案例教学,用商品评论来做词云分析
  • 原文地址:https://blog.csdn.net/pmc0_0/article/details/126578111