- 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镜像
文章插图
前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校验值 , 无需关心
文章插图
每一组MTR生成的redo log都有唯一一个lsn值与之对应 , 其中lsn越小表示对应的redo log产生越早
5.flushed_to_disk_lsn记录刷新到磁盘中的redo日志量redo log总是先写入到redo log buffer然后才会被刷新磁盘中的 , 所有需要有一个变量记录下一次从log buffer中刷盘的起始位置——
buf_next_to_write
文章插图
经验总结扩展阅读
- MySQL的下载、安装、配置
- 我的Vue之旅 09 数据数据库表的存储与获取实现 Mysql + Golang
- 「MySQL高级篇」MySQL之MVCC实现原理&&事务隔离级别的实现
- Mysql InnoDB Buffer Pool
- 「MySQL高级篇」MySQL锁机制 && 事务
- 【MySQL】Navicat15 安装
- 「MySQL高级篇」explain分析SQL,索引失效&&常见优化场景
- 「MySQL高级篇」MySQL索引原理,设计原则
- MySQL 索引失效-模糊查询,最左匹配原则,OR条件等。
- MySQL 全局锁、表级锁、行级锁,你搞清楚了吗?