| 在上篇主机服务器配置中,可设置binlog格式 |
| binlog_format=STATEMENT |
| |
- STATEMENT模式(基于SQL语句的复制(statement-based replication, SBR))
| 每一条会修改数据的sql语句会记录到binlog中。这是默认的binlog格式。 |
| |
| SBR 的优点: |
| 历史悠久,技术成熟 |
| 不需要记录每一行的变化,减少了binlog日志量,文件较小 |
| binlog中包含了所有数据库更改信息,可以据此来审核数据库的安全等情况 |
| binlog可以用于实时的还原,而不仅仅用于复制 |
| 主从版本可以不一样,从服务器版本可以比主服务器版本高 |
| |
| SBR 的缺点: |
| 不是所有的UPDATE语句都能被复制,尤其是包含不确定操作的时候 |
| |
| 使用以下函数的语句也无法被复制:LOAD_FILE()、UUID()、USER()、FOUND_ROWS()、SYSDATE();(除非启动时启用了 --sysdate-is-now 选项) |
| INSERT ... SELECT 会产生比 RBR 更多的行级锁 |
| 复制需要进行全表扫描(WHERE 语句中没有使用到索引)的 UPDATE 时,需要比 RBR 请求更多的行级锁 |
| 对于有 AUTO_INCREMENT 字段的 InnoDB表而言,INSERT 语句会阻塞其他 INSERT 语句 |
| 对于一些复杂的语句,在从服务器上的耗资源情况会更严重,而 RBR 模式下,只会对那个发生变化的记录产生影响 |
| 执行复杂语句如果出错的话,会消耗更多资源 |
| 数据表必须几乎和主服务器保持一致才行,否则可能会导致复制出错 |
- ROW模式(基于行的复制(row-based replication, RBR))
| 5.1.5版本的MySQL才开始支持,不记录每条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模式(混合模式复制(mixed-based replication, MBR)) |
| |
| 在Mixed模式下,一般的语句修改使用statment格式保存binlog。如一些函数,statement无法完成主从复制的操作,则采用row格式保存binlog |
| |
| MySQL会根据执行的每一条具体的sql语句来区分对待记录的日志形式,也就是在Statement和Row之间选择一种 |
双主双从


【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?