什么是MYSQL的两阶段提交?它在解决什么问题?

本文详细解释了两阶段提交在数据库中的应用,通过将redolog分为准备和提交阶段来处理宕机情况,确保在宕机后数据的一致性。特别关注了redolog和binlog的关系,以及如何解决刷盘故障导致的主从数据不一致问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  • 两阶段提交

    • 将redo log拆分成两个阶段,一个是准备阶段,一个是提交阶段

    • 如果在写入redo log之前宕机,那么redo log和bin log中并没有任何数据

    • 如果在写入redo log之后宕机,这时通过事务id并不能在bin log中找到对应的记录,也就意味着并没有写入bin log,所以会执行回滚操作,这是为了保证主机和从机的数据一致

    • 如果在写入bin log后宕机,这时redo log写入完成处于prepare,binlog也写入完成,这时候检査 binlog 中的数据否存在并且完整,如果存在且完整,则直接提交事务,如果不存在或者不完整,则回滚事务

    • 两阶段提交: redolog记录完后将数据状态标记为prepare,接着开始写binlog日志,写完binlog日志后,将redolog日志数据状态修改为commit

  • 解决的问题

    • 主从数据不一致的问题

      • 刷盘时redo log刷盘成功记录到了磁盘上,而binlog在刷盘时,发生宕机导致binlog并没有刷盘成功,因为redolog已经刷盘成功了数据实现了持久化,但是当从机去访问主机的bin log时,这时binlog中的数据并没有修改,因为宕机导致刷盘失败,所以binlog中的数据是错误的,然后从机同步数据后,将错误的数据同步到磁盘中,这时主机和从机的数据不一致

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值