[发明专利]分布式事务处理方法、设备及存储介质在审
申请号: | 202110139205.8 | 申请日: | 2021-02-01 |
公开(公告)号: | CN112835688A | 公开(公告)日: | 2021-05-25 |
发明(设计)人: | 李进 | 申请(专利权)人: | 北京星网锐捷网络技术有限公司 |
主分类号: | G06F9/46 | 分类号: | G06F9/46;G06F9/54;G06F11/14;G06F16/27;G06F16/28 |
代理公司: | 北京太合九思知识产权代理有限公司 11610 | 代理人: | 刘戈;张爱 |
地址: | 100036 北京市海淀区*** | 国省代码: | 北京;11 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 分布式 事务处理 方法 设备 存储 介质 | ||
本申请实施例提供一种分布式事务处理方法、设备及存储介质。在本申请的一些实施例中,分布式事务处理设备接收事务请求端发送的分布式事务的启动请求;根据启动请求,获取预先配置的多个子流程的执行顺序;根据多个子流程的执行顺序,依序执行多个子流程;在目标子流程执行失败后,增加判断是否满足重试的条件,在满足重试的条件的情况下,对目标子流程执行重试操作,在子流程执行失败后增加判断是否满足回滚条件,在满足回滚条件的情况下,从目标子流程开始逆向执行所有已执行子流程的回滚操作,增加分布式事务执行成功的概率,减少因分布式系统的不稳定导致数据不一致性的概率,提升分布式系统故障场景下的自愈能力,提高事务的执行效率。
技术领域
本申请涉及分布式计算领域的技术,尤其涉及一种分布式事务处理方法、设备及存储介质。
背景技术
分布式系统架构中,整个业务流程由多个业务节点提供多个服务共同完成,一个业务逻辑往往需要操作多个服务上的数据。为了保证多个服务的数据一致性,通常需要引入分布式事务机制来处理,每个事务包含着多个节点上的不同业务操作,事务的执行结果只能全部成功或者全部失败。
目前,基于Saga理论的事务模型,将一个长的、执行多个步骤的事务T拆分为多个子事务:t1,t2,...,tm-1,tm,tm+1,...,tn;与此同时,定义每个子事务的回滚逻辑(又称补偿事务):c1,c2,...,cm-1,cm,cm+1,...,cn。上述事务T可以认为是一个完整的分布式事务,每个子事务t认为是事务中的一个步骤,当t1,t2,...,tn这些子事务执行完成后,认为事务T执行完成,达到业务处理目标,并达成业务数据一致性的目标。当某个子事务,例如tm+1在执行过程中失败时,需要依次执行cm,cm-1,...,c2,c1这一系列的补偿事务,完成补偿事务的处理后,整个事务回滚结束,恢复到执行开始前的状态。
基于Saga理论的事务模型,对任意子事务来说,在该子事务执行失败后均需要针对该子事务执行回滚操作,这种处理流程比较繁琐,不够简化,影响事务的执行效率。
发明内容
本申请的多个方面提供一种分布式事务处理方法、设备及存储介质,重新规范子事务执行失败后的处理逻辑,提高事务的执行效率。
本申请实施例提供一种分布式事务处理方法,包括:
接收事务请求端发送的分布式事务的启动请求,所述分布式事务包括多个子流程;
根据所述启动请求,获取预先配置的所述多个子流程的执行顺序;
根据所述多个子流程的执行顺序,依序执行所述多个子流程;
若存在目标子流程执行失败,则判断所述目标子流程是否满足重试的条件;
若是,则对所述目标子流程执行重试操作。
可选地,判断所述目标子流程是否满足重试的条件,包括:
调用执行所述目标子流程过程中使用的RPC接口,得到所述目标子流程对应的网络通信结果;
若网络通信结果为网络通信超时,则所述目标子流程满足重试的条件。
可选地,在对所述目标子流程执行重试操作之后,所述方法还包括:
记录所述目标子流程的重试次数;
若所述目标子流程的重试次数超过设定次数,则向目标管理设备发送提醒指令,以提醒管理人员执行维护操作。
可选地,所述分布式事务还包括:至少部分子流程对应的补偿流程,在判断所述目标子流程是否满足重试的条件之后,所述方法还包括:
若否,则按照所述目标子流程对应的至少一个目标补偿流程的执行顺序,对所述分布式事务执行回滚操作。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于北京星网锐捷网络技术有限公司,未经北京星网锐捷网络技术有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202110139205.8/2.html,转载请声明来源钻瓜专利网。
- 上一篇:数据处理方法、装置及设备
- 下一篇:表单快照回填方法、装置、设备和存储介质