小米科技|一生挚友redo log、binlog《死磕MySQL系列 二》( 四 )
画一幅图让大家能更好的理解掌柜、黑板、在MySQL中的对应关系 。
六、redo log参数详解事务的持久性就是通过重做日志来实现的 。
当提交事务之后 , 并不是直接修改数据库的数据的 , 而是先保证将相关的操作记录到redo日志中 。
数据库会根据相应的机制将内存的中的脏页数据刷新到磁盘中 。
上图是一个简单的重做日志写入流程 。
在上图中提到俩个陌生概念 , Buffer pool、redo log buffer , 这个俩个都是Innodb存储引擎的内存区域的一部分 。
而redo log file是位于磁盘位置 。
也就说当有DML(insert、update、delete)操作时 , 数据会先写入Buffer pool , 然后在写到重做日志缓冲区 。
重做日志缓冲区会根据刷盘机制来进行写入重做日志中 。
这个机制的设置参数为innodb_flush_log_at_trx_commit
, 参数分别为01 , 2
上图即为重做日志的写入策略 。
- 当这个参数的值为0的时 , 提交事务之后 , 会把数据存放到redo log buffer中 , 然后每秒将数据写进磁盘文件
- 当这个参数的值为1的时 , 提交事务之后 , 就必须把redo log buffer从内存刷入到磁盘文件里去 , 只要事务提交成功 , 那么redo log就必然在磁盘里了 。
- 当这个参数的值为2的情况 , 提交事务之后 , 把redo log buffer日志写入磁盘文件对应的os cache缓存里去 , 而不是直接进入磁盘文件 , 1秒后才会把os cache里的数据写入到磁盘文件里去 。
- 当参数为0时 , 前一秒的日志都保存在日志缓冲区 , 也就是内存上 , 如果机器宕掉 , 可能丢失1秒的事务数据 。
- 当参数为1时 , 数据库对IO的要求就非常高了 , 如果底层的硬件提供的IOPS比较差 , 那么MySQL数据库的并发很快就会由于硬件IO的问题而无法提升 。
- 当参数为2时 , 数据是直接写进了os cache缓存 , 这部分属于操作系统部分 , 如果操作系统部分损坏或者断电的情况会丢失1秒内的事务数据 , 这种策略相对于第一种就安全了很多 , 并且对IO要求也没有那么高 。
关于性能:0>2>1
关于安全:1>2>0
根据以上结论 , 所以说在MySQL数据库中 , 刷盘策略默认值为1 , 保证事务提交之后 , 数据绝对不会丢失 。
【小米科技|一生挚友redo log、binlog《死磕MySQL系列 二》】坚持学习、坚持写作、坚持分享是咔咔从业以来所秉持的信念 。 愿文章在偌大的互联网上能给你带来一点帮助 , 我是咔咔 , 下期见 。
- 小米科技|不聊性能只谈拍照!新旗舰反向升级成潮流,拍照手机如何选?
- 华为|别不信!魅族如今处境,雷军早有预料,小米也早已体验
- 小米科技|预算只有两三千买这三款,颜值性能卓越,没有超高预算的用户看看
- CPU|元宇宙+高端制造+人工智能!公司已投高科技超100亿,股价仅3元
- 小米科技|RTX3060的性能到底如何?相比RTX2060提升有多大?
- 蓝思科技|苹果与34家中国供应商断绝合作,央视呼吁:尽快摆脱对苹果依赖
- 小米 11 Ultra 内测 NFC“读写勿扰”与“解锁后使用”功能
- 一加科技|16+1TB,一加10T秀肌肉,顶级4nm+5100mAh+80W
- 飞利浦·斯塔克|最便宜的小米 12 来了,2000 块左右
- 小米科技|从4999跌至2889元,2K曲面屏+IP68防水,小米老款旗舰售价大跳水