二段提交协议、三段提交协议

2024-04-25 12:38
文章标签 协议 提交 三段 二段

本文主要是介绍二段提交协议、三段提交协议,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、二段提交协议

2pc
提交事务阶段------投票阶段
协调者发起事务请求到所有的参与者,参与者接收到事务请求后判断自身情况,如果不能执行事务,则反馈不能提交事务,返回NO,如果可以就执行事务,并将undo和redo信息记录事务日志中,反馈Yes

执行事务阶段
协调者收到所有参与者反馈Yes就发布commit命令,否则如果超时未收到或者收到NO 那么发布回滚命令。

参与者收到commit的请求后正式提交事务操作,提交后释放资源。完成事务后向协调者发送ack消息  协调者收到所有参与者的ack后完成事务。

参与者收到rollback的请求查找undo记录,完成回滚后释放资源。完成事务后向协调者发送ack消息  协调者收到所有参与者的ack后中断事务。

优点:原理简单,实现方便

缺点:同步阻塞,单点问题,脑裂问题,太过保守--超时机制,数据不一致---第二阶段部分事务提交。

2、三阶段提交协议

3pc

第一阶段

cancommit

1、协调者向所有参与者发布包含事务内容的canCommit命令,等待参与者回应。

2、参与者认为自身能执行,则返回yes。否则返回NO

第二阶段

preCommit阶段

1、如果协调者收到的反馈都是yes,那么发出preCommit命令,进入prepared阶段,参与者收到preCommit命令后,执行事务操作。并写入undo和redo信息到事务日志中。然后想协调者反馈ack相应

2、如果协调者收到的返回时NO,那么发布abort命令。各参与者收到abort或者超时,都中断事务。

第三阶段,

docommit阶段

如果协调者收到所有参与者的ack相应,那么会发出doCommit命令,所有参与者收到docommit命令就提交事务,然后释放资源。向协调者发出ack。协调者收到所有参与者的ack详细后完成事务。

如果协调者收到No反馈或者超时响应后,将对所有的参与者发出abort请求。各个参与者收到abort请求后会利用undo信息回滚事务。,然后释放资源,反馈ack。协调者收到所有ack消息后,中断事务。

需要注意的是,在第三阶段如果参与者没有收到docommit命令,那么超时后它会提交事务,毕竟第一阶段所有的参与者都响应了,默认他们都能正常工作。

优缺点:

优点:即第三阶段的超时提交。降低了参与者的阻塞范围,并且能够再出现单点故障后继续达成一致。

缺点:数据可能也会不一致。也存在2pc中的缺点


这篇关于二段提交协议、三段提交协议的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/934710

相关文章

Git如何修改已提交人的用户名和邮箱

《Git如何修改已提交人的用户名和邮箱》文章介绍了如何修改Git已提交人的用户名和邮箱,包括注意事项和具体步骤,确保操作正确无误... 目录git修改已提交人的用户名和邮箱前言第一步第二步总结git修改已提交人的用户名和邮箱前言需注意以下两点内容:需要在顶层目录下(php就是 .git 文件夹所在的目

javaScript在表单提交时获取表单数据的示例代码

《javaScript在表单提交时获取表单数据的示例代码》本文介绍了五种在JavaScript中获取表单数据的方法:使用FormData对象、手动提取表单数据、使用querySelector获取单个字... 方法 1:使用 FormData 对象FormData 是一个方便的内置对象,用于获取表单中的键值

Qt 中集成mqtt协议的使用方法

《Qt中集成mqtt协议的使用方法》文章介绍了如何在工程中引入qmqtt库,并通过声明一个单例类来暴露订阅到的主题数据,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一,引入qmqtt 库二,使用一,引入qmqtt 库我是将整个头文件/源文件都添加到了工程中进行编译,这样 跨平台

Redis 多规则限流和防重复提交方案实现小结

《Redis多规则限流和防重复提交方案实现小结》本文主要介绍了Redis多规则限流和防重复提交方案实现小结,包括使用String结构和Zset结构来记录用户IP的访问次数,具有一定的参考价值,感兴趣... 目录一:使用 String 结构记录固定时间段内某用户 IP 访问某接口的次数二:使用 Zset 进行

Git提交代码详细流程及问题总结

《Git提交代码详细流程及问题总结》:本文主要介绍Git的三大分区,分别是工作区、暂存区和版本库,并详细描述了提交、推送、拉取代码和合并分支的流程,文中通过代码介绍的非常详解,需要的朋友可以参考下... 目录1.git 三大分区2.Git提交、推送、拉取代码、合并分支详细流程3.问题总结4.git push

Java如何接收并解析HL7协议数据

《Java如何接收并解析HL7协议数据》文章主要介绍了HL7协议及其在医疗行业中的应用,详细描述了如何配置环境、接收和解析数据,以及与前端进行交互的实现方法,文章还分享了使用7Edit工具进行调试的经... 目录一、前言二、正文1、环境配置2、数据接收:HL7Monitor3、数据解析:HL7Busines

作业提交过程之HDFSMapReduce

作业提交全过程详解 (1)作业提交 第1步:Client调用job.waitForCompletion方法,向整个集群提交MapReduce作业。 第2步:Client向RM申请一个作业id。 第3步:RM给Client返回该job资源的提交路径和作业id。 第4步:Client提交jar包、切片信息和配置文件到指定的资源提交路径。 第5步:Client提交完资源后,向RM申请运行MrAp

【Linux】应用层http协议

一、HTTP协议 1.1 简要介绍一下HTTP        我们在网络的应用层中可以自己定义协议,但是,已经有大佬定义了一些现成的,非常好用的应用层协议,供我们直接使用,HTTP(超文本传输协议)就是其中之一。        在互联网世界中,HTTP(超文本传输协议)是一个至关重要的协议,他定义了客户端(如浏览器)与服务器之间如何进行通信,以交换或者传输超文本(比如HTML文档)。

HTML提交表单给python

python 代码 from flask import Flask, request, render_template, redirect, url_forapp = Flask(__name__)@app.route('/')def form():# 渲染表单页面return render_template('./index.html')@app.route('/submit_form',

Python3 BeautifulSoup爬虫 POJ自动提交

POJ 提交代码采用Base64加密方式 import http.cookiejarimport loggingimport urllib.parseimport urllib.requestimport base64from bs4 import BeautifulSoupfrom submitcode import SubmitCodeclass SubmitPoj():de