MySQL 意外宕机怎么办,数据会丢么?数据怎么恢复吗?

当InnoDB发生意外宕机,数据通常不会丢失,因为有重做日志(redo log)保证数据可恢复。恢复过程分为两阶段:首先依赖redo log进行数据恢复,通过checkpoint找到开始恢复的位置,解析并应用redo log;其次,结合binlog和undo log判断未提交事务状态,确保数据一致性。在MySQL 5.7以后,恢复过程进行了优化,包括减少对数据字典的依赖和提高恢复速度。
摘要由CSDN通过智能技术生成

InnoDB如果发生意外宕机了,数据会丢么?

对于这个问题,稍微了解一点MySQL知识的人,都会斩钉截铁的回答:不会!

为什么?

他们也会毫不犹豫地说:因为有重做日志(redo log),数据可以通过redo log进行恢复。

回答得很好,那么InnoDB怎样通过redo log进行数据恢复的,具体的流程是怎样的?

估计能说清楚这个问题的人所剩不多了,更深入一点:除了redo log,InnoDB在恢复过程中,还需要其他信息么?比如是否需要binlog参与?undo日志在恢复过程中又会起到什么作用?

到这里,可能很多人会变得疑惑起来:数据恢复跟undo有半毛钱的关系?

其实,InnoDB的数据恢复是一个很复杂的过程,这个恢复过程需要redo log、binlog、undo log等参与。这里把InnoDB的恢复过程主要划分为两个阶段:

第一阶段主要依赖于redo log的恢复;

而第二阶段,恰恰需要binlog和undo log的共同参与。

接下来,我们来具体了解下整个恢复的过程:

一、依赖redo log进行恢复

第一阶段,数据库启动后,InnoDB会通过redo log找到最近一次checkpoint的位置,然后根据checkpoint相对应的LSN开始,获取需要重做的日志,接着解析获取的日志并且保存到一个哈希表中,最后通过遍历哈希表中的redo log信息,读取相关页进行恢复。

InnoDB的checkpoint信息保存在日志文件中,即ib_logfile0的开始2048个字节中,checkpoint有两个,交替更新,checkpoint与日志文件的关系如下图:

(checkpoint位置)

checkpoint信息分别保存在ib_logfile0的512字节和1536字节处,每个checkpoint默认大小为512字节,InnoDB的checkpoint主要由3部分信息组成:

checkpoint no:主要保存的是checkpoint号,因为InnoDB有两个checkpoint,通过checkpoint号来判断哪个checkpoint更新。

check

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值