[发明专利]分布式框架的事务处理方法及装置在审
申请号: | 201810998303.5 | 申请日: | 2018-08-29 |
公开(公告)号: | CN109324925A | 公开(公告)日: | 2019-02-12 |
发明(设计)人: | 代伟;杨学海 | 申请(专利权)人: | 北京仁科互动网络技术有限公司 |
主分类号: | G06F11/14 | 分类号: | G06F11/14 |
代理公司: | 北京路浩知识产权代理有限公司 11002 | 代理人: | 王莹;李相雨 |
地址: | 100020 北京市朝阳区朝阳北路2*** | 国省代码: | 北京;11 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 子单元 分布式框架 异常消息 调用程序 目标服务 事务处理 子服务 回滚 分布式集群 单元接收 业务异常 进程 灵活的 逆序 调用 检测 配置 事务 | ||
本发明实施例提供一种分布式框架的事务处理方法及装置。所述方法包括:检测到第一单元接收到进程异常消息后,获取所述第一单元的子单元;其中,所述第一单元执行一目标服务,每个所述子单元执行一所述目标服务的子服务,且所述子服务具有执行次序;依据所述执行次序,逆序对所述子单元执行回滚,确定所述进程异常消息对应的目标子单元;确定调用所述目标子单元的目标调用程序,将所述进程异常消息抛出至所述目标调用程序。本发明实施例提供了一种处理分布式集群环境中的业务异常问题的方式,以保障分布式框架中事务的完整性;同时为各个单元或子单元提供了灵活的回滚配置。
技术领域
本发明实施例涉及计算机技术领域,尤其涉及一种分布式框架的事务处理方法及装置。
背景技术
分布式环境是将不同地点、具有不同功能或拥有不同数据的多台计算机通过通信网络连接起来的一种计算机系统,其在控制系统的统一管理控制下,协调地完成大规模信息处理任务。在分布式集群环境中,有些业务需要跨多个服务来完成,而这些服务在调用过程中可能会出现业务异常,从而导致整个事务的不完整,因此,需要提供一种处理业务异常的方式,以实现对事务的完整性进行保障。
发明内容
本发明实施例提供一种分布式框架的事务处理方法及装置,其目的是为了提供一种处理分布式集群环境中的业务异常问题的方式。
一方面,本发明实施例提供一种分布式框架的事务处理方法,所述方法包括:
检测到第一单元接收到进程异常消息后,获取所述第一单元的子单元;其中,所述第一单元执行一目标服务,每个所述子单元执行一所述目标服务的子服务,且所述子服务具有执行次序;
依据所述执行次序,逆序对所述子单元执行回滚,确定所述进程异常消息对应的目标子单元;
确定调用所述目标子单元的目标调用程序,将所述进程异常消息抛出至所述目标调用程序。
另一方面,本发明实施例提供一种分布式框架的事务处理装置,所述装置包括:
获取模块,用于检测到第一单元接收到进程异常消息后,获取所述第一单元的子单元;其中,所述第一单元执行一目标服务,每个所述子单元执行一所述目标服务的子服务,且所述子服务具有执行次序;
回滚模块,用于依据所述执行次序,逆序对所述子单元执行回滚,确定所述进程异常消息对应的目标子单元;
抛出模块,用于确定调用所述目标子单元的目标调用程序,将所述进程异常消息抛出至所述目标调用程序。
另一方面,本发明实施例还提供了一种电子设备,包括存储器、处理器、总线以及存储在存储器上并可在处理器上运行的计算机程序,所述处理器执行所述程序时实现上述分布式框架的事务处理方法中的步骤。
再一方面,本发明实施例还提供了一种非暂态计算机可读存储介质,其上存储有计算机程序,所述程序被处理器执行时实现上述分布式框架的事务处理方法中的步骤。
本发明实施例提供的分布式框架的事务处理方法及装置,检测到第一单元接收到进程异常消息后,获取所述第一单元的子单元;依据子单元执行子服务的执行次序,逆序对所述子单元执行回滚,以确定所述进程异常消息对应的目标子单元,并进一步确定调用所述目标子单元的目标调用程序,将所述进程异常消息抛出至所述目标调用程序;本发明实施例提供了一种处理分布式集群环境中的业务异常问题的方式,以保障分布式框架中事务的完整性;同时为各个单元或子单元提供了灵活的回滚配置,在出现故障时可自动控制故障单元进行回滚,并向上抛出进程异常消息,便于目标调用程序及时处理进程异常。
附图说明
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于北京仁科互动网络技术有限公司,未经北京仁科互动网络技术有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201810998303.5/2.html,转载请声明来源钻瓜专利网。