推广

必须了解的mysql三大日志-binlog、redo log和undo log

iseeyu2年前 (2024-02-21)推广175

image

mysql 支持三种将 redo log buffer 写入 redo log file 的时机,可以通过 innodb_flush_log_at_trx_commit 参数配置,各参数值含义如下:

参数值 含义
0(延迟写) 事务提交时不会将 redo log buffer 中日志写入到 os buffer ,而是每秒写入 os buffer 并调用 fsync() 写入到 redo log file 中。也就是说设置为0时是(大约)每秒刷新写入到磁盘中的,当系统崩溃,会丢失1秒钟的数据
1(实时写,实时刷) 事务每次提交都会将 redo log buffer 中的日志写入 os buffer 并调用 fsync() 刷到 redo log file 中。这种方式即使系统崩溃也不会丢失任何数据,但是因为每次提交都写入磁盘,IO的性能较差。
2(实时写,延迟刷) 每次提交都仅写入到 os buffer ,然后是每秒调用 fsync()os buffer中的日志写入到 redo log file

image

redo log记录形式

前面说过, redo log 实际上记录数据页的变更,而这种变更记录是没必要全部保存,因此 redo log
实现上采用了大小固定,循环写入的方式,当写到结尾时,会回到开头循环写日志。如下图:

image

同时我们很容易得知, 在innodb中,既有redo log 需要刷盘,还有 数据页 也需要刷盘, redo log存在的意义主要就是降低对 数据页 刷盘的要求 ** 。在上图中, write pos 表示 redo log 当前记录的 LSN (逻辑序列号)位置, check point 表示 数据页更改记录 刷盘后对应 redo log 所处的 LSN(逻辑序列号)位置。write poscheck point 之间的部分是 redo log 空着的部分,用于记录新的记录;check pointwrite pos 之间是 redo log 待落盘的数据页更改记录。当 write pos追上 check point时,会先推动 check point 向前移动,空出位置再记录新的日志。

启动 innodb 的时候,不管上次是正常关闭还是异常关闭,总是会进行恢复操作。因为 redo log记录的是数据页的物理变化,因此恢复的时候速度比逻辑日志(如 binlog )要快很多。重启 innodb 时,首先会检查磁盘中数据页的 LSN ,如果数据页的 LSN 小于日志中的 LSN ,则会从 checkpoint 开始恢复。还有一种情况,在宕机前正处于
checkpoint 的刷盘过程,且数据页的刷盘进度超过了日志页的刷盘进度,此时会出现数据页中记录的 LSN 大于日志中的 LSN
,这时超出日志进度的部分将不会重做,因为这本身就表示已经做过的事情,无需再重做。

redo log与binlog区别

|
| redo log | binlog |
| — | — | — |
| 文件大小 | redo log 的大小是固定的。 | binlog 可通过配置参数 max_binlog_size 设置每个binlog 文件的大小。 |
| 实现方式 | redo logInnoDB 引擎层实现的,并不是所有引擎都有。 | binlogServer 层实现的,所有引擎都可以使用 binlog 日志 |
| 记录方式 | redo log 采用循环写的方式记录,当写到结尾时,会回到开头循环写日志。 | binlog通过追加的方式记录,当文件大小大于给定值后,后续的日志会记录到新的文件上 |
| 适用场景 | redo log 适用于崩溃恢复(crash-safe) | binlog 适用于主从复制和数据恢复 |

binlogredo log 的区别可知:binlog 日志只用于归档,只依靠 binlog 是没有 crash-safe 能力的。但只有 redo log 也不行,因为 redo logInnoDB
特有的,且日志上的记录落盘后会被覆盖掉。因此需要 binlogredo log
二者同时记录,才能保证当数据库发生宕机重启时,数据不会丢失。

undo log

数据库事务四大特性中有一个是 原子性 ,具体来说就是 原子性是指对数据库的一系列操作,要么全部成功,要么全部失败,不可能出现部分成功的情况
。实际上, 原子性 底层就是通过 undo log 实现的。undo log 主要记录了数据的逻辑变化,比如一条 INSERT 语句,对应一条 DELETEundo log ,对于每个 UPDATE 语句,对应一条相反的 UPDATEundo log ,这样在发生错误时,就能回滚到事务之前的数据状态。同时, undo log 也是 MVCC(多版本并发控制)实现的关键,这部分内容在 面试中的老大难-mysql事务和锁,一次性讲清楚!中有介绍,不再赘述。

扫描二维码推送至手机访问。

版权声明:本文由西安泽虎代运营发布,如需转载请注明出处。

转载请注明出处https://www.0291.com.cn/post/57514.html

相关文章

如何根据网站的特色制定网站推广方案。

如何根据网站的特色制定网站推广方案。

一个新网站的上线,势必会做网站推广,那么,如果用较为常见的推广方案的话,不能说没有什么效果,很明显的,这是没有根据自己的网站特色来做适合自己网站的推广方案计划,可想而知,一个较好的适合自己网站的推广方案是多么的重要。 网站推广方案,简单来说,我们可以从以下几个方面来指定: (1...

TikTok&德勤:2022电商出海营销白皮书。

TikTok&德勤:2022电商出海营销白皮书。

随着线上化购物方式成为全球消费的常态,全球电商市场保持高速增长,新市场、新商机不断涌现。然而,全球经济普遍下行、消费者信心不足,也成为出海电商发展必须面对的挑战。 为了帮助中国出海企业主抓住全球电商增长新机遇,TikTok for Business 携手第三方调研机构德勤咨询,对全球重点电商市...

营销型网站建设的用户体验度优化技巧。

营销型网站建设的用户体验度优化技巧。

在建站时,就开始以日后的营销推广为目的作为出发点,并贯彻到的每一个环节中,以使得营销型网站一上线便具备李优秀的营销功能。那么营销型网站的优化技巧有哪些你知道吗? 如何提升企业网站的客户体验是营销型企业网站必须考虑的重要问题,客户体验在我们的现代营销中无处不存在其身影。接下来介绍提高用户体...

天猫入驻费用标准有哪些(天猫入驻流程及费用标准)

天猫入驻费用标准有哪些(天猫入驻流程及费用标准)

天猫店铺在淘宝众多类型的店铺中,天然权重是最高的一种,能够更加容易获得消费者的认可,在直通车等工具的使用中,也有明显的优势。也正是因为这些优势,开一家天猫店需要的条件和费用也是比较多的...

我来分享要求必然胚胎,互联电商的o2o是“小而美的”。

我来分享要求必然胚胎,互联电商的o2o是“小而美的”。

PC时代的霸主是否也如西班牙足球般落幕。 与iPhone6相比,iPhone6s在发售同期内的国内激活设备量有小幅下降iPhone6s的国内激活设备规模与去年同期iPhone6国内上市17天后的数字相比,下降了16%。这个层面不需要考量太多,仅从两个方面入手足矣,第一个投放经验是否丰富。规模性工业...

浅谈网络营销与网络推广的区别及目的。

浅谈网络营销与网络推广的区别及目的。

在互联网的大背景驱使下,不论是大企业还是小企业都会利用网络的方式将自己的产品推广出去或者运用的方式提升品牌的有名度,或许大部分人认为就是网络营销,其实它们之间也是有很多不同之处,首先,我们先了解网络营销与网络推广的含义。 一、什么是网络营销,实现方式有哪些? 实际上网络营销就是以...

现在,非常期待与您的又一次邂逅

我们努力让每一部企业宣传片和抖音短视频成为商业大片