浅谈MySQL的redo日志

经常删库跑路的朋友们都知道,MySQL数据库主从同步是通过binlog来实现的,binlog中记录的是MySQL数据库行记录的变化或者是sql语句。MySQL的redo日志记录的是物理页的变化,redo日志用于事务回滚和数据库崩溃恢复。

那么,为什么MySQL数据库不使用redo日志进行主从同步呢?

我想,这是一个半开放式的问题。先来聊聊使用binlog做主从同步的特点。

1、实现跨平台。如果binlog使用statement格式,那么不同操作系统上的数据库都能识别并回放binlog。

2、binlog记录的是数据库的逻辑变化,不论格式是row、statement还是mixed,从库在回放时都不容易出错。

3、binlog是server层管理的,所有的存储引擎都支持binlog功能。

4、binlog日志通过追加的方式不断续写,直到文件大小达到阈值才会切换下一个。

5、事务需要等到提交时,才会开始写binlog日志,因此大小不是固定的。

redo日志的特点。

1、redo日志文件的大小是固定的,一般是16kb。

2、redo日志记录的是MySQL的物理数据页的变化,因此数据库在崩溃恢复的时候,使用redo恢复会很快完成。

3、redo是通过循环写入的方式切换的,假设一组里面设置了5个redo日志,这5个redo日志会循环写入,直到5个日志都写满,又会从头开始覆盖第一个redo日志开始写。

4、redo日志在两阶段提交时,事务一边进行就会一边写redo,不需要等到事务提交才写redo。

5、MySQL数据库目前只有innodb日志支持redo。

既然redo是记录物理页的变化,在强制主从都用innodb存储引擎情况下,如果主从复制用redo进行同步,主库一边执行事务,就会一边写redo日志,等到事务提交时只需要写剩下的一点点redo,即可提交。就能一边回放,一边等待主库提交,并且应用redo日志速度肯定要比binlog速度快。

大家对于MySQL主从同步是使用redo更好还是使用binlog更好,有啥想法呢,欢迎评论区一起交流。

相关推荐
Hello.Reader11 分钟前
Flink SQL Window Top-N窗口榜单的正确打开方式
数据库·sql·flink
wsx_iot14 分钟前
MySQL 的 MVCC(多版本并发控制)详解
数据库·mysql
Shingmc316 分钟前
MySQL表的增删改查
数据库·mysql
敲上瘾19 分钟前
MySQL主从集群解析:从原理到Docker实战部署
android·数据库·分布式·mysql·docker·数据库架构
电子_咸鱼20 分钟前
【QT——信号和槽(1)】
linux·c语言·开发语言·数据库·c++·git·qt
pandarking20 分钟前
[CTF]攻防世界:web-unfinish(sql二次注入)
前端·数据库·sql·web安全·ctf
程序猿202323 分钟前
MySQL索引性能分析
数据库·mysql
TDengine (老段)26 分钟前
TDengine 新性能基准测试工具 taosgen
大数据·数据库·物联网·测试工具·时序数据库·tdengine·涛思数据
波波仔8626 分钟前
行存储与列存储的区别
数据库·clickhouse·行存储·列储存
小光学长26 分钟前
ssm农民养殖经验交流与分享平台bc046578(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
java·数据库·spring