您的位置:首页 > 房产 > 建筑 > Mysql binlog 三种模式

Mysql binlog 三种模式

2025/1/24 5:44:58 来源:https://blog.csdn.net/chenyao1994/article/details/140903318  浏览:    关键词:Mysql binlog 三种模式

        在MySQL中,binlog(二进制日志)有三种主要的模式,它们决定了二进制日志中记录信息的详细程度。这些模式对于复制、数据恢复以及审计等场景非常重要。以下是这三种模式:

  1. STATEMENT

    • 描述:在STATEMENT模式下,MySQL会记录每一条会修改数据的SQL语句(不包括SELECT和SHOW这类的语句)。这意味着,当日志被应用到slave或从binlog恢复数据时,MySQL会尝试重新执行这些SQL语句。
    • 优点:产生的日志量较小,因为只记录SQL语句本身。
    • 缺点:某些情况下,由于SQL语句的执行结果依赖于执行时的上下文(如当前时间、数据库环境变量等),可能无法准确地复现原始操作,尤其是在使用函数(如NOW())或包含用户变量的情况下。
  2. ROW

    • 描述:在ROW模式下,MySQL会记录每一行数据的变化情况,包括每一行数据在修改前后的具体内容。这使得复制和恢复操作非常精确,因为每一行数据的变化都被直接记录了下来。
    • 优点:可以精确地复制或恢复数据,不依赖于执行时的上下文。
    • 缺点:由于记录了每一行数据的变化,因此产生的日志量通常比STATEMENT模式大很多,尤其是在进行大量数据修改操作时。
  3. MIXED

    • 描述:MIXED模式是STATEMENT和ROW模式的混合。MySQL会根据SQL语句的实际情况来决定使用哪种模式记录日志。如果MySQL认为使用STATEMENT模式可以安全地复现原始操作,就会使用STATEMENT模式;否则,会使用ROW模式。
    • 优点:结合了STATEMENT和ROW模式的优点,既尽可能地减少了日志量,又保证了复制和恢复的准确性。
    • 缺点:在某些情况下,MySQL可能无法准确地判断使用哪种模式更合适,这可能导致意外的日志模式选择。

设置binlog模式

        可以通过MySQL的配置文件(通常是my.cnfmy.ini)来设置binlog的模式。例如,要设置binlog模式为MIXED,可以在配置文件中添加或修改以下行:

[mysqld] 
binlog_format = MIXED

注意:修改配置后需要重启MySQL服务才能生效。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com