Java面试八股之MySQL中binlog的工作模式有哪些

  1. MySQL中binlog的工作模式有哪些

MySQL的二进制日志(binlog)用于记录所有更改数据的事务,这对于数据恢复、主从复制和点在时间恢复等功能至关重要。MySQL提供了三种不同的binlog工作模式,它们分别是:

Statement-based replication (SBR)(基于语句的复制):

在这种模式下,MySQL记录下执行的SQL语句,而不是数据变化的具体细节。

这意味着binlog将包含如INSERT, UPDATE, DELETE等语句。

Statement模式的优点是它产生的binlog文件较小,因为只记录了SQL语句而非大量数据。

缺点是在某些情况下,由于语句的上下文差异或使用了非确定性函数(如RAND()或NOW()),可能在从服务器上产生不同的结果,导致数据不一致。

Row-based replication (RBR)(基于行的复制):

Row模式下,MySQL记录每个事务中改变的每一行数据的前后状态。

这种模式不关心具体的SQL语句,而是专注于数据的变化。

Row模式的优点是它可以准确地复制数据变化,避免了由语句差异引起的不一致性问题。

缺点是它会产生较大的binlog文件,因为需要记录每一行数据的变化。

Mixed-based replication (MBR)(混合模式复制):

Mixed模式是一种结合了Statement和Row模式优点的模式。

MySQL通常使用Statement模式来记录事务,但对于那些可能导致数据不一致的语句(如使用了非确定性函数的语句),它会自动切换到Row模式。

这种模式试图平衡binlog文件大小和数据一致性之间的关系。

在MySQL中,可以通过设置binlog_format系统变量来指定使用哪种复制模式。默认情况下,MySQL通常配置为使用Mixed模式。

如果大家需要视频版本的讲解,欢迎关注我的B站:

相关推荐
крон8 分钟前
【Auto.js例程】华为备忘录导出到其他手机
开发语言·javascript·智能手机
zh_xuan42 分钟前
c++ 单例模式
开发语言·c++·单例模式
coderSong256844 分钟前
Java高级 |【实验八】springboot 使用Websocket
java·spring boot·后端·websocket
老胖闲聊1 小时前
Python Copilot【代码辅助工具】 简介
开发语言·python·copilot
Blossom.1181 小时前
使用Python和Scikit-Learn实现机器学习模型调优
开发语言·人工智能·python·深度学习·目标检测·机器学习·scikit-learn
Mr_Air_Boy2 小时前
SpringBoot使用dynamic配置多数据源时使用@Transactional事务在非primary的数据源上遇到的问题
java·spring boot·后端
曹勖之2 小时前
基于ROS2,撰写python脚本,根据给定的舵-桨动力学模型实现动力学更新
开发语言·python·机器人·ros2
豆沙沙包?2 小时前
2025年- H77-Lc185--45.跳跃游戏II(贪心)--Java版
java·开发语言·游戏
军训猫猫头2 小时前
96.如何使用C#实现串口发送? C#例子
开发语言·c#
年老体衰按不动键盘3 小时前
快速部署和启动Vue3项目
java·javascript·vue