MYSQL binlog_format 解释

本文详细对比了MySQL5.1中基于行复制(RBR)与基于SQL语句复制(SBR)两种复制模式的优缺点,包括binlog格式、性能、安全性及适用场景。
MySQL 5.1 中,在复制方面的改进就是引进了新的复制技术:基于行的复制。简言之,这种新技术就是关注表中发生变化的记录,而非以前
的照抄 binlog 模式。从 MySQL 5.1.12 开始,可以用以下三种模式来实现:基于SQL语句的复制(statement-based replication, SBR),基于行的复制(row-based replication, RBR),混合模式复制(mixed-based replication, MBR)。相应地,binlog的格式也有三种:STATEMENT,ROW,MIXED。MBR 模式中,SBR 模式是默认的。

在运行时可以动态低改变binlog的格式,除了以下几种情况:
存储过程或者触发器中间
启用了NDB
当前会话试用 RBR 模式,并且已打开了临时表
如果binlog采用了 MIXED 模式,那么在以下几种情况下会自动将binlog的模式由 SBR 模式改成 RBR 模式。
当DML语句更新一个NDB表时
当函数中包含 UUID() 时
2个及以上包含 AUTO_INCREMENT 字段的表被更新时
行任何 INSERT DELAYED 语句时
用 UDF 时
视图中必须要求使用 RBR 时,例如创建视图是使用了 UUID() 函数
设定主从复制模式的方法非常简单,只要在以前设定复制配置的基础上,再加一个参数:
binlog_format="STATEMENT"
#binlog_format="ROW"
#binlog_format="MIXED"


当然了,也可以在运行时动态修改binlog的格式。例如
mysql> SET SESSION binlog_format = 'STATEMENT';
mysql> SET SESSION binlog_format = 'ROW';
mysql> SET SESSION binlog_format = 'MIXED';


mysql> SET GLOBAL binlog_format = 'STATEMENT';
mysql> SET GLOBAL binlog_format = 'ROW';
mysql> SET GLOBAL binlog_format = 'MIXED';


现在来比较以下 SBR 和 RBR 2中模式各自的优缺点:
SBR 的优点:
历史悠久,技术成熟
binlog文件较小
binlog中包含了所有数据库更改信息,可以据此来审核数据库的安全等情况
binlog可以用于实时的还原,而不仅仅用于复制
主从版本可以不一样,从服务器版本可以比主服务器版本高


SBR 的缺点:
不是所有的UPDATE语句都能被复制,尤其是包含不确定操作的时候。
调用具有不确定因素的 UDF 时复制也可能出问题
使用以下函数的语句也无法被复制:
* LOAD_FILE()
* UUID()
* USER()
* FOUND_ROWS()
* SYSDATE() (除非启动时启用了 --sysdate-is-now 选项)
INSERT ... SELECT 会产生比 RBR 更多的行级锁
复制需要进行全表扫描(WHERE 语句中没有使用到索引)的 UPDATE 时,需要比 RBR 请求更多的行级锁
对于有 AUTO_INCREMENT 字段的 InnoDB表而言,INSERT 语句会阻塞其他 INSERT 语句
对于一些复杂的语句,在从服务器上的耗资源情况会更严重,而 RBR 模式下,只会对那个发生变化的记录产生影响
存储函数(不是存储过程)在被调用的同时也会执行一次 NOW() 函数,这个可以说是坏事也可能是好事
确定了的 UDF 也需要在从服务器上执行
数据表必须几乎和主服务器保持一致才行,否则可能会导致复制出错
执行复杂语句如果出错的话,会消耗更多资源


RBR 的优点:
任何情况都可以被复制,这对复制来说是最安全可靠的
和其他大多数数据库系统的复制技术一样
多数情况下,从服务器上的表如果有主键的话,复制就会快了很多
复制以下几种语句时的行锁更少:
* INSERT ... SELECT
* 包含 AUTO_INCREMENT 字段的 INSERT
* 没有附带条件或者并没有修改很多记录的 UPDATE 或 DELETE 语句
执行 INSERT,UPDATE,DELETE 语句时锁更少
从服务器上采用多线程来执行复制成为可能


RBR 的缺点:
binlog 大了很多
复杂的回滚时 binlog 中会包含大量的数据
主服务器上执行 UPDATE 语句时,所有发生变化的记录都会写到 binlog 中,而 SBR 只会写一次,这会导致频繁发生 binlog 的并发写问题
UDF 产生的大 BLOB 值会导致复制变慢
无法从 binlog 中看到都复制了写什么语句
当在非事务表上执行一段堆积的SQL语句时,最好采用 SBR 模式,否则很容易导致主从服务器的数据不一致情况发生


另外,针对系统库 mysql 里面的表发生变化时的处理规则如下:
如果是采用 INSERT,UPDATE,DELETE 直接操作表的情况,则日志格式根据 binlog_format 的设定而记录
如果是采用 GRANT,REVOKE,SET PASSWORD 等管理语句来做的话,那么无论如何都采用 SBR 模式记录
注:采用 RBR 模式后,能解决很多原先出现的主键重复问题。
<think> 我们参考了提供的引用,特别是引用[1]和引用[4]中提到了binlog_format的设置。根据引用[3],我们知道Mixed模式是Statement和Row的结合,MySQL会根据具体情况选择记录方式。现在用户希望在不重启数据库的情况下将binlog_format从MIXED改为ROW。 根据MySQL的官方文档,binlog_format是动态全局变量,可以在运行时修改,但需要注意作用范围。 步骤如下: 1. 确认当前会话和全局的binlog_format设置。 2. 设置全局binlog_format为ROW。 3. 设置当前会话的binlog_format(可选,但为了保证当前会话也生效,可以设置)。 4. 确保所有正在运行的会话都使用新的设置(可能需要重新连接会话)。 但是,需要注意的是,修改全局变量后,只会对新建立的连接生效,已经存在的连接(除了当前连接)不会改变其binlog_format设置。因此,为了确保所有后续的binlog都使用ROW格式,我们需要将全局变量设置为ROW,并且确保所有新的连接都使用这个设置。同时,建议重启应用程序(即重新建立数据库连接)以保证所有连接都使用新的设置。 另外,根据引用[2],在Mixed模式下,某些情况下会自动转为ROW模式。而我们的目标是要完全使用ROW模式,所以修改为ROW模式是可行的。 操作步骤(在MySQL命令行中执行): 1. 查看当前的binlog_format设置: ```sql SHOW GLOBAL VARIABLES LIKE 'binlog_format'; SHOW VARIABLES LIKE 'binlog_format'; ``` 2. 设置全局binlog_format为ROW: ```sql SET GLOBAL binlog_format = 'ROW'; ``` 3. 为了当前会话也生效,可以设置会话级别(可选): ```sql SET SESSION binlog_format = 'ROW'; ``` 4. 再次确认设置已经生效: ```sql SHOW GLOBAL VARIABLES LIKE 'binlog_format'; -- 应该显示ROW SHOW VARIABLES LIKE 'binlog_format'; -- 当前会话显示ROW ``` 注意:即使设置了全局变量,已经存在的连接(除了当前连接)仍然会使用原来的设置(MIXED)。因此,为了确保所有连接都使用ROW格式,需要重启应用程序(即让应用重新连接MySQL),这样新连接就会使用全局设置。 另外,根据引用[4],修改binlog_format可能涉及到配置文件的变化,如果希望永久生效,应该修改配置文件(如my.cnf)中的binlog_format选项,并设置为ROW。这样在MySQL重启后仍然有效。但用户要求不重启数据库,所以只做动态设置即可。 总结:通过SET GLOBAL命令可以动态修改binlog_format为ROW,但需要确保所有应用重新连接数据库以使用新的设置。 相关问题: 1. 修改binlog_format为ROW后,对主从复制有什么影响? 2. ROW模式和MIXED模式在复制安全性上有何区别? 3. 如何永久修改MySQLbinlog_format设置? </think> ### MySQLbinlog_format 从 MIXED 改为 ROW 不重启数据库的方法 根据引用内容(特别是引用[1][2][3]),MySQL 的 `binlog_format` 支持动态修改,无需重启数据库。以下是具体操作步骤: #### ✅ 操作步骤 1. **查看当前模式**(确认当前为 MIXED): ```sql SHOW GLOBAL VARIABLES LIKE 'binlog_format'; -- 输出应为:binlog_format | MIXED ``` 2. **修改为 ROW 模式**: ```sql SET GLOBAL binlog_format = 'ROW'; ``` 3. **验证修改结果**: ```sql SHOW GLOBAL VARIABLES LIKE 'binlog_format'; -- 输出应为:binlog_format | ROW ``` #### ⚠️ 注意事项 1. **作用范围**: - `SET GLOBAL` 对新连接生效,**已有连接仍使用原模式**(需重启应用连接)。 - 建议同时修改会话级设置确保当前操作生效: ```sql SET SESSION binlog_format = 'ROW'; ``` 2. **持久化配置**: - 动态修改在重启后会失效(引用[4]中的配置示例)。 - 需在配置文件(如 `my.cnf`)永久生效: ```ini [mysqld] binlog_format = ROW ``` 3. **主从复制影响**: - 修改后新生成的 binlog 使用 ROW 格式 - 从库需兼容 ROW 格式(MySQL 5.1.5+ 支持) #### 💡 ROW 模式优势(引用[2][3]) 1. 数据一致性更强,避免主从不一致问题 2. 更安全处理:`UUID()`、`AUTO_INCREMENT` 等特殊场景 3. 存储过程/函数复制更可靠 > **关键提示**:Mixed 模式在特定条件下自动转为 ROW(如更新含 `AUTO_INCREMENT` 的多表时)[^2],直接使用 ROW 模式可避免模式切换带来的复杂度。 --- ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值