MLOG_MULTI_REC_END
类型的日志 。
四丶redo log日志写入过程1.redo log block
文章插图
innodb 将通过MTR生成的redo log放在大小为512字节的block中 , 其中存储redo log的部分只有
log block body
其余的两部分存储一些统计信息- log block header
- log_block_hdr_no:每一个block 具备一个大于0的唯一编号,此属性便是记录编号值
- log_block_hdr_data_len:记录当前lock block使用了多少字节(从12开始,因为lock block header占用了12字节),随着越来越多的日志写入block最后最大为512字节
- log_block_first_rec_group:一个MTR包含多个日志,这个字段记录该block中第一个MTR生成redo log日志记录组的偏移量 。
- log_block_checkpoint_no:表示checkpoint的序号
- log block trailer
- log_block_check_sum:表示block检验和,用于正确性校验
文章插图
innodb_log_buffer_size
可以指定其大?。?6mb3.redo log写入log bufferinnodb保存了一个
buf_free
的全局变量用于记录log buffer中空闲位置的偏移量,让后续redo log的写入从buf_free的位置开始写 。不同的事务是可以并发运行的,并发的写入redo log buffer中 , 每当一个MTR执行完成时,伴随着该MTR生成的redo log被写入到log buffer中,多个不同事务的MTR可能时交替写如到log buffer中的
五丶redo log持久化1.redo log buffer中的内容何时持久化到磁盘MTR运行过程中产生的一组redo log会在MTR结束的时候被复制到log buffer中,但是何时落盘昵?
- log buffer 空间不足
如果写入log buffer的redo log日志量已经占满log buffer的一半时,会进行刷盘
- 事务提交时
之所以使用redo log,是由于其占用内存小 , 可以顺序IO写回磁盘 , 为了保证事务的持久性,需要把修改页面对应的redo log刷新到磁盘,这样系统崩溃时也可以将已提交的事务使用redo log进行恢复
- 将某个脏页刷新到磁盘前
将buffer pool中的脏页刷盘的时候,会保证将其之前产生的redo log刷盘
- 后台线程,每秒一次的频率将redo log buffer中刷盘
- 正常关闭mysql服务器时
- 做checkpoint时
ib_logfile0
和ib_logfile1
,log buffer中的内容便是刷新到着两个文件中 。可以通过以下系统变量进行设置innodb_log_group_home_dir
:指定redo log日志文件所在目录innodb_log_file_size
:指定每一个redo log日志文件大小innodb_log_file_in_group
:指定redo log日志文件的个数
ib_logfile数字
格式的名称,在持久化redo log的时候,首先从ib_logfile0
开始写,然后写ib_logfile1
直到写到最后一个文件,这时候需要做checkpoint
,后继续从ib_logfile0
写 , 从头开始写,写到末尾就又回到开头循环写 , 如下图文章插图
3.redo log日志文件格式
文章插图
每一个redo log文件前2048个字节(四个redo log block大?。┯美创娲⒐芾硇畔ⅲ?后续的位置存储log buffer中redo log block镜像
文章插图
【Mysql InnoDB Redo log】前2048字节分为四个block , 如上图
- log file header 描述该日志的一些整体属性
- checkpoint1 & checkpoint2,格式相同
- log_checkpoint_no:服务器执行checkpoint的编号,每执行一次checkpoint该值加1
- log_checkpoint_lsn:服务器在结束checkpoint时对应的lsn值,系统崩溃时从该值开始
- log_checkpoint_offset:log_checkpoint_lsn属性值,在redo日志文件组中的偏移量
- log_checkpoint_log_buf_size:服务器在执行checkpoint操作时对应的log buffer大小
- log_checkpoint_checksum:本block校验值,无需关心
推荐阅读
- MySQL的下载、安装、配置
- 我的Vue之旅 09 数据数据库表的存储与获取实现 Mysql + Golang
- 「MySQL高级篇」MySQL之MVCC实现原理&&事务隔离级别的实现
- Mysql InnoDB Buffer Pool
- 「MySQL高级篇」MySQL锁机制 && 事务
- 【MySQL】Navicat15 安装
- 「MySQL高级篇」explain分析SQL,索引失效&&常见优化场景
- 「MySQL高级篇」MySQL索引原理,设计原则
- MySQL 索引失效-模糊查询,最左匹配原则,OR条件等。
- MySQL 全局锁、表级锁、行级锁,你搞清楚了吗?