前段时间,有一个读者后台问我:民工哥,我前几天去面试,就因为我简历上写着精通 MySQL,面试官就一个劲的追着我问:什么 binlog,redo log,而且还是怎么细就怎么问,搞我的一脸懵逼。。。
当时,我也看到这话也是一脸懵逼的状态,只是呵呵一笑,回了他一句:老弟,你都工作 3 年了,连 bin log、redo log 都不知道,不应该啊。。。
所以,今天,民工哥就上次那位读者遇到的问题,分享一下这方面相关的知识,希望对后面要去面试,或者学习这块的读者有一定帮助或参考价值。如果你感觉文章对你有用,请不要吝啬你的在看与转发支持,民工哥在这先谢谢大家了。
首先,我们先来看看一次查询/更新语句流程图
本文会将重点放在执行器<->存储引擎之间的交互。
mysql不是每次数据更改都立刻写到磁盘,而是会先将修改后的结果暂存在内存中,当一段时间后,再一次性将多个修改写到磁盘上,减少磁盘io成本,同时提高操作速度。
在同一个事务中,每当数据库进行修改数据操作时,将修改结果更新到内存后,会在redo log添加一行记录记录“需要在哪个数据页上做什么修改”,并将该记录状态置为prepare,等到commit提交事务后,会将此次事务中在redo log添加的记录的状态都置为commit状态,之后将修改落盘时,会将redo log中状态为commit的记录的修改都写入磁盘。过程如下图
redolog 的大小是固定的,在?mysql?中可以通过修改配置参数innodb\_log\_files\_in\_group 和 innodb\_log\_file\_size 配置日志文件数量和每个日志文件大小,redolog 采用循环写的方式记录,当写到结尾时,会回到开头循环写日志。如下图
write pos表示日志当前记录的位置,当ib\_logfile\_4写满后,会从ib\_logfile\_1从头开始记录;check point表示将日志记录的修改写进磁盘,完成数据落盘,数据落盘后checkpoint会将日志上的相关记录擦除掉,即write pos->checkpoint之间的部分是redo log空着的部分,用于记录新的记录,checkpoint->write pos之间是redo log待落盘的数据修改记录。当writepos追上checkpoint时,得先停下记录,先推动checkpoint向前移动,空出位置记录新的日志。建议收藏备查!MySQL 常见错误代码说明
有了redo log,当数据库发生宕机重启后,可通过redo log将未落盘的数据恢复,即保证已经提交的事务记录不会丢失。
binlog和redo log必须保持一致,不允许出现binlog有记录但redolog没有的情况,反之亦然。之前说过在一个事务中,redolog有prepare和commit两种状态,所以,在redolog状态为prepare时记录binlog可保证两日志的记录一致,下图列出各种情况来说明。
现在我们再来看看整个完整的流程图
作者:会玩code
链接:https://www.jianshu.com/p/4bc...
简介: 世界免疫周丨后疫情时代,医院如何变得更有智慧 最近几天,印度成为了全...
如果你喜欢我的文章,希望点赞?? 收藏 ?? 评论 ?? 三连支持一下,谢谢你,这对我...
为什么要使用Application Cache技术? 在HTML5之前,我们需要接入网络才能访问,...
什么东西都离不开基础,建房子需要地基,解方程式需要先学会乘法表,唱歌需要先...
当你开始做一个项目的时候,用线框图把你的想法勾勒出来非常重要。这是你把想法...
CSS3 --添加阴影(盒子阴影的使用) CSS3 - 给div或者文字添加阴影(盒子阴影、...
问题描述 按钮样式为图标+文字,在使用flex布局写垂直居中时,iphone7手机上文字...
使用CSS3 border-image 属性,你可以在元素的周围设置图片边框。 一、浏览器支持...
CSS中定位有四种在不同的场景下有不同的作用下面我就大体的介绍一下这四种定位. ...
怎么了?除非你对某类对话框已司空见惯,否则遇到,第一反应往往是这样的?这种体...