[发明专利]基于SAGA的分布式事务实现方法以及装置在审
申请号: | 202111621008.6 | 申请日: | 2021-12-27 |
公开(公告)号: | CN114327796A | 公开(公告)日: | 2022-04-12 |
发明(设计)人: | 黎育龙;刘亮;田健;刘庆庆;易剑 | 申请(专利权)人: | 中国邮政储蓄银行股份有限公司 |
主分类号: | G06F9/46 | 分类号: | G06F9/46;G06F16/23;G06F16/27;G06Q40/04 |
代理公司: | 北京康信知识产权代理有限责任公司 11240 | 代理人: | 张岳峰 |
地址: | 100032*** | 国省代码: | 北京;11 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 基于 saga 分布式 事务 实现 方法 以及 装置 | ||
1.一种基于SAGA的分布式事务实现方法,其特征在于,包括:
将SAGA事务协调器与组合服务绑定,得到绑定组合服务,所述SAGA事务协调器用于协调所述组合服务的分布式事务相关层操作,并且起到监控事务的作用;
采用所述绑定组合服务执行分布式事务。
2.根据权利要求1所述的方法,其特征在于,所述组合服务中包括多个原子服务,采用所述绑定组合服务执行分布式事务,包括:
确定是否出现异常情况,所述异常情况包括所述原子服务返回错误码、所述原子服务没有返回和所述组合服务异常中的至少一种;
在出现所述异常情况的情况下,采用所述绑定组合服务中的所述SAGA事务协调器触发补偿操作对所述异常情况进行补偿;
在对所有的所述异常情况补偿成功的情况下,确定所述分布式事务执行成功。
3.根据权利要求2所述的方法,其特征在于,在出现所述异常情况的情况下,采用所述绑定组合服务中的所述SAGA事务协调器触发补偿操作对所述异常情况进行补偿,包括:
在出现所述异常情况的情况下,触发即时补偿机制对所述异常情况进行补偿;
在即时补偿失败的情况下,触发事后恢复机制对所述异常情况进行补偿;
在事后恢复失败的情况下,触发人工介入机制对所述异常情况进行补偿。
4.根据权利要求3所述的方法,其特征在于,所述原子服务的执行状态存储在子事务登记簿中,在出现所述异常情况的情况下,触发即时补偿机制对所述异常情况进行补偿,包括:
在出现所述异常情况的情况下,逆序查询所述子事务登记簿,并获取各所述原子服务对应的补偿服务;
采用所述补偿服务对所述原子服务进行补偿。
5.根据权利要求4所述的方法,其特征在于,采用所述补偿服务对所述原子服务进行补偿,之后,所述方法还包括:
根据第一补偿结果,更新所述子事务登记簿。
6.根据权利要求3所述的方法,其特征在于,所述组合服务的执行状态存储在主事务登记簿中,在即时补偿失败的情况下,触发事后恢复机制对所述异常情况进行补偿,包括:
在所述即时补偿失败的情况下,从所述主事务登记簿中将未正常完成的所述组合服务拷贝到待补偿交易登记簿中;
顺序读取所述待补偿交易登记簿中的所述组合服务,且对各所述组合服务中的所述原子服务进行补偿。
7.根据权利要求6所述的方法,其特征在于,顺序读取所述待补偿交易登记簿中的所述组合服务,且对各所述组合服务中的所述原子服务进行补偿之后,所述方法还包括:
根据第二补偿结果,更新所述主事务登记簿和所述待补偿交易登记簿。
8.一种基于SAGA的分布式事务实现装置,其特征在于,包括:
绑定单元,将SAGA事务协调器与组合服务绑定,得到绑定组合服务,所述SAGA事务协调器用于协调所述组合服务的分布式事务相关层操作,并且起到监控事务的作用;
执行单元,用于采用所述绑定组合服务执行分布式事务。
9.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质包括存储的程序,其中,在所述程序运行时控制所述计算机可读存储介质所在设备执行权利要求1至7中任意一项所述的方法。
10.一种处理器,其特征在于,所述处理器用于运行程序,其中,所述程序运行时执行权利要求1至7中任意一项所述的方法。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于中国邮政储蓄银行股份有限公司,未经中国邮政储蓄银行股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202111621008.6/1.html,转载请声明来源钻瓜专利网。