Innodb通过Buffer Pool、Redo Log、Log Buffer、Undo Log来实现事务,以一个update语句为例:
1、Innodb在收到一个update语句后,首先会根据条件找到数据所在的页,并将该页缓存到Buffer Pool中
2、执行update语句,修改Buffer Pool中的数据,也就是内存中的数据
3、针对update语句生成一个Redo Log对象,并将Redo Log对象存入到Log Buffer(Log Buffer是一块内存区域)中
4、同时针对update语句生成Undo Log日志,用于事务回滚
5、如果事务提交成功,那么则把Redo Log对象进行持久化,后续还有其它机制将Buffer Pool中所修改的数据页持久化到磁盘中
6、如果事务提交失败,则利用Undo Log 日志进行回滚
查看Buffer Pool的内存大小的SQL命令:
SHOW GLOBAL VARIABLES LIKE '%innodb_buffer_pool_size%';
默认情况下Buffer Pool的内存大小为128MB