两阶段是哪两阶段?
1、准备阶段
2、提交阶段
涉及的角色:
1、协调者(记做老大),统一管理所有节点事务的提交和回滚
2、参与者(记做小弟),实际处理事务的独立节点
准备阶段做了哪些事情?
1、老大开始本地事务,向所有的小弟节点发起事务开始请求
2、小弟们收到老大的事务请求以后开始执行本地事务,并记录本地日志,方便后续有异常回滚,然后返回老大成功还是失败,但是不提交本地事务、不释放锁资源
提交阶段做了哪些事情?
这个分两种情况:
一、所有的小弟都返回成功
1、老大收到小弟们的成功响应之后,通知各小弟提交本地事务
2、小弟提交完本地事务、释放锁资源,然后响应老大事务提交结果
3、老大接到小弟的响应后提交本地事务
二、有小弟返回失败
1、老大接到小弟们的响应以后,如果发现有失败,通知各小弟回滚事务
2、小弟们开始回滚事务、释放锁资源,然后响应老大事务回滚完毕
3、老大接到小弟的响应后提交回滚本地事务
二阶段提交协议存在的问题:
1、在二阶段小弟的事务提交或回滚之前,由于是没有释放锁资源的,所以当有其他请求访问锁定的资源时会处于等待状态
2、由于老大只有一个,万一事务执行期间老大挂掉了,所有的小弟都是处于资源锁定状态
3、老大向所有的小弟发送提交事务请求的时候,万一有小弟没有收到提交事务的请求,那么这部分小弟的数据就有可能跟其他小弟的不一样,会有数据不一致的问题
4、如果老大混的比较惨,只有一个小弟:当老大发出提交事务的请求之后宕机了,同时小弟也宕机了,那么就不能确定小弟的事务到底是提交完了没有