两阶段提交协议

两阶段是哪两阶段?

1、准备阶段

2、提交阶段

涉及的角色:

1、协调者(记做老大),统一管理所有节点事务的提交和回滚

2、参与者(记做小弟),实际处理事务的独立节点

准备阶段做了哪些事情?

1、老大开始本地事务,向所有的小弟节点发起事务开始请求

2、小弟们收到老大的事务请求以后开始执行本地事务,并记录本地日志,方便后续有异常回滚,然后返回老大成功还是失败,但是不提交本地事务、不释放锁资源

提交阶段做了哪些事情?

这个分两种情况:

一、所有的小弟都返回成功

1、老大收到小弟们的成功响应之后,通知各小弟提交本地事务

2、小弟提交完本地事务、释放锁资源,然后响应老大事务提交结果

3、老大接到小弟的响应后提交本地事务

二、有小弟返回失败

1、老大接到小弟们的响应以后,如果发现有失败,通知各小弟回滚事务

2、小弟们开始回滚事务、释放锁资源,然后响应老大事务回滚完毕

3、老大接到小弟的响应后提交回滚本地事务

二阶段提交协议存在的问题:

1、在二阶段小弟的事务提交或回滚之前,由于是没有释放锁资源的,所以当有其他请求访问锁定的资源时会处于等待状态

2、由于老大只有一个,万一事务执行期间老大挂掉了,所有的小弟都是处于资源锁定状态

3、老大向所有的小弟发送提交事务请求的时候,万一有小弟没有收到提交事务的请求,那么这部分小弟的数据就有可能跟其他小弟的不一样,会有数据不一致的问题

4、如果老大混的比较惨,只有一个小弟:当老大发出提交事务的请求之后宕机了,同时小弟也宕机了,那么就不能确定小弟的事务到底是提交完了没有

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值