中间件三阶段提交(3PC, Three-Phase Commit)

简介: 【7月更文挑战第16天】

image.png
三阶段提交(3PC,Three-Phase Commit)是分布式系统中用于保证事务原子性和一致性的协议之一。它是在两阶段提交(2PC,Two-Phase Commit)的基础上改进而来的,目的是为了减少在协调者(Coordinator)失败时的阻塞问题。3PC将整个提交过程分为三个阶段,分别是:

  1. CanCommit(准备阶段)

    • 协调者向所有参与者(Participants)询问是否可以提交事务,并等待所有参与者的回复。
    • 参与者执行事务操作,但并不提交,而是将操作保存到一个临时状态中,并返回给协调者是否可以继续。
  2. PreCommit(预提交阶段)

    • 如果协调者收到所有参与者的肯定回复,它会向所有参与者发送预提交请求,要求参与者进入预提交状态。
    • 参与者在收到预提交请求后,将事务标记为预提交状态,并记录下这个状态,但是不真正提交事务。
  3. DoCommit(提交阶段)

    • 协调者根据预提交阶段的结果决定是否正式提交事务。如果决定提交,它会向所有参与者发送提交命令;如果决定不提交,则向所有参与者发送回滚命令。
    • 参与者在收到提交命令后,正式提交事务并释放所有资源锁;如果是回滚命令,则进行事务回滚并释放资源锁。

3PC通过引入预提交阶段,减少了因协调者失败导致的阻塞情况。在预提交阶段,即使协调者失败,参与者也可以根据预提交状态自行完成事务的提交或回滚,无需等待协调者再次发出指令。

然而,3PC也有其缺点,例如,相比2PC,它的网络通信次数更多,这可能会增加系统的延迟和开销。此外,在某些情况下,如果参与者在预提交阶段之后、最终提交之前失败,恢复过程可能变得复杂。

目录
相关文章
|
6月前
|
中间件 数据库
|
8月前
|
消息中间件 存储 负载均衡
消息中间件的选择:RabbitMQ是一个明智的选择
消息中间件的选择:RabbitMQ是一个明智的选择
120 0
|
7月前
|
消息中间件 存储 中间件
【消息中间件】详解三大MQ:RabbitMQ、RocketMQ、Kafka
【消息中间件】详解三大MQ:RabbitMQ、RocketMQ、Kafka
1830 0
|
6月前
|
消息中间件 编解码 Docker
Docker部署RabbitMQ消息中间件
【7月更文挑战第4天】Docker部署RabbitMQ消息中间件
287 3
|
3月前
|
消息中间件 编解码 Docker
【Docker项目实战】Docker部署RabbitMQ消息中间件
【10月更文挑战第8天】Docker部署RabbitMQ消息中间件
132 1
【Docker项目实战】Docker部署RabbitMQ消息中间件
|
5月前
|
消息中间件 Java 测试技术
消息中间件RabbitMQ---SpringBoot整合RabbitMQ【三】
这篇文章是关于如何在SpringBoot应用中整合RabbitMQ的消息中间件。内容包括了在SpringBoot项目中添加RabbitMQ的依赖、配置文件设置、启动类注解,以及如何通过单元测试来创建交换器、队列、绑定,并发送和接收消息。文章还介绍了如何配置消息转换器以支持对象的序列化和反序列化,以及如何使用注解`@RabbitListener`来接收消息。
消息中间件RabbitMQ---SpringBoot整合RabbitMQ【三】
|
5月前
|
消息中间件 Docker 容器
消息中间件RabbitMQ---Docker安装RabbitMQ、以及RabbitMQ的基本使用【二】
这篇文章提供了RabbitMQ的安装和基本使用教程,包括如何使用Docker拉取RabbitMQ镜像、创建容器、通过浏览器访问管理界面,以及如何创建交换机、队列、绑定和使用direct、fanout和topic三种类型的交换器进行消息发布和接收的测试。
消息中间件RabbitMQ---Docker安装RabbitMQ、以及RabbitMQ的基本使用【二】
|
5月前
|
消息中间件 存储 网络协议
消息中间件RabbitMQ---概述和概念 【一】
该文章提供了对消息中间件RabbitMQ的全面概述,包括其核心概念、工作原理以及与AMQP和JMS的关系。
消息中间件RabbitMQ---概述和概念 【一】
|
6月前
|
消息中间件 监控 负载均衡
中间件RabbitMQ性能瓶颈
【7月更文挑战第13天】
354 11
|
6月前
|
消息中间件 NoSQL Kafka
消息中间件(RocketMQ、RabbitMQ、ActiveMQ、Redis、kafka、ZeroMQ)以及之间的区别
消息中间件(RocketMQ、RabbitMQ、ActiveMQ、Redis、kafka、ZeroMQ)以及之间的区别