MySQL更新语句执行过程

执行流程

  1. 加载id=1的记录所在的整页数据到缓存池;
  2. 旧值写入undolog便于回滚;
  3. 更新内存数据;
  4. 写redo log到RedoBuff;
  5. redo log顺序写入磁盘,准备提交事务(prepare阶段);
  6. 准备提交事务,binlog写入磁盘;
  7. 写入commit标记到redo log文件里,提交事务完成,该标记为了保证事务提交后redo  log和binlog数据一致;
  8. 系统空闲时,随机写入磁盘,以page为单位写入。

为什么MySQL不直接更新磁盘上的数据而设置这么一套复杂的机制来执行SQL?

因为来一个请求就直接对磁盘文件进行随机读写,然后更新磁盘文件里的数据性能可能相当差,所以直接更新磁盘文件不能让数据库抗住高并发。

MySQL这套机制看起来复杂,但他可以保证每个更新请求都是更新内存BufferPool,然后顺序写日志文件,同时还能保证各种异常情况下的数据一致性。

更新内存的性能是极高的,然后顺序写磁盘上的日志文件的性能也是远高于随机读写磁盘文件的。

正是通过这套机制,才能让MySQL在较高配置的机器上每秒可以抗下几千甚至上万的读写请求。

什么是redo log和binlog的2阶段提交?

prepare阶段:

  • 这个阶段SQL已经执行并更新BufferPool内存数据
  • 生成redo log到redolog buff并开始顺序写入磁盘

binlog写入磁盘持久化

commit:写入commit标记到redo log文件里,提交事务完成

什么是WAL机制?

先写redo log后刷新数据库文件的机制叫做WAL(Write-Ahead Logging)机制,效率更高。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值