MySql三大日志——(八股)

undolog,redolog,binlog三大日志

undo log是Innodb存储引擎层生成的日志,实现了事物的原子性,主要用于事务回滚和MVCC,在事务没提交之前,Innodb会先记录更新前的数据记录undo log中,回滚时利润undo log来进行回滚。

redo log是Innodb存储引擎层的日志,属于物理日志,记录了某个数据页做了什么修改,实现了事物的持久性,主要用于掉电等故障恢复。比如某个事务提交了,脏页数据还没有刷盘,如果MySql机器断电了,脏页的数据就丢失了,MySql重启后可以通过redolog日志,可以将已提交事物的数据恢复回来。

binlog是Server层生成的日志,主要用于数据备份和主从复制。在完成一条更新操作后,Server层会生成一条binlog,等之后事务提交的时候,会将事务执行过程中产生的所有binlong同意写入binlog文件。binlog文件记录了所有数据库表结构变更和表和数据修改的日志,不会记录查询类的操作。

redoLog和binlog的使用场景:

使用对象不同:

binlog是MySQL的Server层实现的日志,所有存储引擎都可以使用

redolog是Innodb存储引擎实现的日志

文件格式不同:

binlog有3中文件格式类型:分别是STATEMENT,ROW,MIXED

STATEMENT:每一条修改数据的SQL都会被记录到BINLOG中(相当于记录了逻辑操作,所以针对这种格式,binlog可以被称为逻辑日志),主从复制中slave端再根据SQL语句重现

ROW:记录行数据最终被修改成什么样了(这种格式的日志,就不能称为逻辑日志了)。ROW的缺点是每行数据的变化结果都会被记录,比如批量update语句,更新多少行数据就会产生多少条记录,是binlog文件过大,而在STATEMENT格式下只会记录下一条update语句。

MIXED:包含了STATEMENT和ROW模式,它会根据不同的情况自己使用ROW模式和STATEMENT模式

redolog是物理日志,记录的是某个数据页做了什么修改,比如对什么表什么数据页的偏移量的地方做了什么更新

写入方式不同:

binlog是追加写,写满一个文件,就创建一个新的文件继续写,不会覆盖以前的日志,保存的是全量的日志

redolog是循环写,日志空间大小是固定的,全部写满就从太开始,保存为被刷入磁盘的脏页日志。

用途不同:

binlog用于备份恢复,主从复制

redolog用于掉电故障恢复

相关推荐
李广坤17 小时前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
Turnip12022 天前
深度解析:为什么简单的数据库"写操作"会在 MySQL 中卡住?
后端·mysql
爱可生开源社区2 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1772 天前
《从零搭建NestJS项目》
数据库·typescript
加号33 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏3 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐3 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
百锦再3 天前
Django实现接口token检测的实现方案
数据库·python·django·sqlite·flask·fastapi·pip
WeiXin_DZbishe3 天前
基于django在线音乐数据采集的设计与实现-计算机毕设 附源码 22647
javascript·spring boot·mysql·django·node.js·php·html5
tryCbest3 天前
数据库SQL学习
数据库·sql