[发明专利]一种分布式事务的处理方法和装置在审
申请号: | 202011176360.9 | 申请日: | 2020-10-28 |
公开(公告)号: | CN113760924A | 公开(公告)日: | 2021-12-07 |
发明(设计)人: | 姜振飞 | 申请(专利权)人: | 北京沃东天骏信息技术有限公司;北京京东世纪贸易有限公司 |
主分类号: | G06F16/23 | 分类号: | G06F16/23;G06F16/2455;G06F16/27;G06F16/215 |
代理公司: | 中原信达知识产权代理有限责任公司 11219 | 代理人: | 张效荣;王志远 |
地址: | 100176 北京市北京经济技术*** | 国省代码: | 北京;11 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 分布式 事务 处理 方法 装置 | ||
本发明公开了一种分布式事务的处理方法和装置,涉及计算机技术领域。该方法的一具体实施方式包括:拦截事务注解,根据事务注解确定待处理事务;将待处理事务对应的事务状态更新为准备状态;其中,待处理事务包括主事务和子事务;对主事务执行本地存储,在主事务对应的本地数据库存储执行成功的情况下,对子事务执行缓存操作。该实施方式能够满足特定场景(如高并发、大流量的微服务互相调用的情况下,主事务与子事务隶属于同一事务时),简化事务处理流程,提高事务处理的自动化程度,同时保持数据一致性的技术效果。
技术领域
本发明涉及计算机技术领域,尤其涉及一种分布式事务的处理方法和装置。
背景技术
分布式事务指事务的参与者、支持事务的服务器、资源服务器以及事务管理器分别位于不同的分布式系统的不同节点之上。常见的分布式事务的解决方案有2PC(Two-phase Commit,二阶段提交,在计算机网络以及数据库领域内,为了使基于分布式系统架构下的所有节点在进行事务提交时保持一致性而设计的一种算法);TCC方案(是由Try/Confirm/Cancel(准备阶段/执行阶段/取消阶段)构成,其Try/Confirm/Cancel业务在执行时,会访问资源管理器来存取数据;以及本地消息表方案(该方案的核心是将需要分布式处理的任务通过消息日志的方式来异步执行)
在实现本发明过程中,发明人发现现有技术中至少存在如下问题:
现有的分布式事务主要需要保证不同数据库的数据一致性,在特定场景下(如高并发、大流量的微服务互相调用的情况下、主事务与子事务共同构成同一事务时),现有的分布式处理方法存在事务处理流程复杂、事务处理自动化程度低和数据难以保持一致的问题。
发明内容
有鉴于此,本发明实施例提供一种分布式事务的处理方法和装置,能够满足特定场景(如高并发、大流量的微服务互相调用的情况下、主事务与子事务共同构成同一事务),简化事务处理流程,提高事务处理的自动化程度,同时保持数据一致性。
为实现上述目的,根据本发明实施例的第一方面,提供了一种分布式事务的处理方法,包括:
拦截事务注解,根据事务注解确定待处理事务;
将待处理事务对应的事务状态更新为准备状态;其中,待处理事务包括主事务和子事务;
对主事务执行本地数据库存储,在主事务对应的本地数据库存储执行成功的情况下,对子事务执行缓存操作。
进一步地,根据事务注解确定待处理事务的步骤包括:
对事务注解进行解析处理,根据解析处理结果确定主事务和子事务;其中,主事务和子事务对应的事务注解是根据业务需求进行确定的。
进一步地,在将待处理事务对应的事务状态更新为准备状态的步骤之后,方法还包括:
将待处理事务对应的事务信息进行本地记录,得到事务信息记录集合。
进一步地,子事务为至少一个;对子事务执行缓存操作的步骤包括:
将事务信息记录集合中各子事务的事务状态更新为执行状态;
根据子事务的事务编号依次对子事务执行缓存操作。
进一步地,若任一个子事务对应的缓存操作执行失败,方法还包括:
将事务信息记录集合中待处理事务的事务状态更新为删除状态;
依次删除已经操作完成的待处理事务,并对待处理事务执行回滚操作。
进一步地,在子事务对应的缓存操作执行完成之后,方法还包括:
从事务信息记录集合中将相应操作执行完成的待处理事务对应的事务记录进行删除处理。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于北京沃东天骏信息技术有限公司;北京京东世纪贸易有限公司,未经北京沃东天骏信息技术有限公司;北京京东世纪贸易有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202011176360.9/2.html,转载请声明来源钻瓜专利网。