**问题:**MySQL innodb存储引擎中的事务是如何通过日志来实现的?
基本流程如下:
- 因为事务在修改页时,要先记undo(数据被修改前的前镜像),在记undo之前要记undo的redo;
原因:undo的中保存数据被修改前的前镜像数据这一行为,也会涉及undo保存前镜像数据而导致的修改页的操作,故会有redo数据的产生;这和Oracle的redo机制一致:只要发生数据块的改变,redo日志就会记录;MySQL对应的是数据页,Oracle对应的是数据块(默认8k); - 然后修改数据页,再记数据页修改的redo。Redo(里面包括undo的修改)是顺序写,所以一定比数据页先持久化到磁盘。
- 当事务需要回滚时,因为有undo,可以把数据页回滚到前镜像的状态,崩溃恢复时,如果redo log中事务没有对应的commit记录,那么需要用undo把该事务的修改回滚到事务开始之前。如果有commit记录,就用redo前滚到该事务完成时并提交掉。
文章至此。
以下为个人公众号,欢迎扫码关注:


302

被折叠的 条评论
为什么被折叠?



