一种分布式事务的流程保障方法及装置制造方法及图纸

技术编号:22220887 阅读:22 留言:0更新日期:2019-09-30 02:25
本发明专利技术实施例涉及计算机技术领域,尤其涉及一种分布式事务的流程保障方法及装置,用以解决分布式事务异常处理机制缺乏灵活性的问题。本发明专利技术实施例包括:接收调用系统发送的处理请求;根据处理请求确定主流程以及N个子流程,N≥1;针对N个子流程中的任一子流程,将子流程向对应的子系统发送,以使子系统对子流程进行处理;对N个子流程的处理过程进行监控,当任一子流程的处理过程出现异常时,根据异常类型、主流程类型以及子流程类型确定对应的异常处理策略;根据异常处理策略对子流程进行异常处理,异常处理包括对已经处理成功的子流程执行非对称反向操作,非对称反向操作为执行反向子流程,反向子流程与已经处理的子流程非对称。

A Process Guarantee Method and Device for Distributed Transaction

【技术实现步骤摘要】
一种分布式事务的流程保障方法及装置
本专利技术涉及金融科技(Fintech)中的计算机
,尤其涉及一种分布式事务的流程保障方法及装置。
技术介绍
随着金融科技,尤其是互联网科技金融的不断发展,越来越多的技术(如分布式、区块链Blockchain、人工智能等)应用在金融领域,但金融业也对技术提出了更高的要求,如针对分布式事务的事务保障过程。分布式事务提供一种机制将一个活动涉及的所有操作纳入到一个不可分割的执行单元,组成事务的所有操作只有在所有操作均能正常执行的情况下方能提交,只要其中任一操作执行失败,都将导致整个事务的回滚。现有得到分布式事务处理方案通常是按照从子事务失败点逆向顺序冲正的方式回滚整个前置处理逻辑,无法做到冲正逻辑的灵活性和差异性。
技术实现思路
本申请提供一种分布式事务的流程保障方法及装置,用以解决分布式事务异常处理机制缺乏灵活性的问题。本专利技术实施例提供的一种分布式事务的流程保障方法,包括:接收调用系统发送的处理请求;根据所述处理请求确定主流程以及N个子流程,N≥1;针对所述N个子流程中的任一子流程,将所述子流程向对应的子系统发送,以使所述子系统对子流程进行处理;对N个子流程的处理过程进行监控,当任一子流程的处理过程出现异常时,根据异常类型、所述主流程的类型以及所述子流程的类型确定对应的异常处理策略;根据所述异常处理策略对子流程进行异常处理,所述异常处理包括对已经处理成功的子流程执行非对称反向操作,所述非对称反向操作为执行反向子流程,所述反向子流程与所述已经处理的子流程非对称。一种可选的实施例中,所述N个子流程中包括异步子流程;所述针对所述N个子流程中的任一子流程,将所述子流程向对应的子系统发送,以使所述子系统对子流程进行处理之后,还包括:针对所述异步子流程,以设置的频率向所述异步子流程对应的异步子系统发送结果查询请求,直至接收到所述异步子系统反馈的处理结果。一种可选的实施例中,所述根据所述异常处理策略对子流程进行异常处理,包括:针对所述异步子流程,执行重试处理。一种可选的实施例中,所述对N个子流程的处理过程进行监控,包括:对所述主流程以及每个子流程的处理时间进行监控,若所述主流程和/或任一子流程的处理时间超过对应的时间阈值,则确定出现超时类异常;所述根据所述异常处理策略对子流程进行异常处理,包括:针对异步子流程出现超时类异常,则对所述异步子流程执行重试处理;针对主流程和/或同步子流程出现超时类异常,向所述调用系统反馈处理过程超时,并确定超时子流程的处理状态;若所述超时子流程的处理状态明确,则对已处理成功的子流程执行非对称反向操作;若所述超时子流程的处理状态不明确,则对所述主流程转批量异步处理。一种可选的实施例中,所述若所述超时子流程的处理状态不明确,则对所述主流程转批量异步处理,包括:间隔预定时间段后,向所述超时子流程对应的子系统发送结果查询请求;若接收到所述子系统发送的处理成功结果,则对所述超时子流程以及所述超时子流程之前的子流程执行非对称反向操作;若接收到所述子系统发送的处理失败结果,则对所述超时子流程之前的子流程执行非对称反向操作;若接收到所述子系统发送的处理结果不明确反馈,则执行所述间隔预定时间段后,向所述超时子流程对应的子系统发送结果查询请求的步骤。一种可选的实施例中,所述接收调用系统发送的处理请求,包括:统计接收到的处理请求的数量;若所述处理请求的数量大于流量预警值,则向所述调用系统发送预警消息,并控制向所述调用系统反馈响应报文的时间。一种可选的实施例中,所述针对所述N个子流程中的任一子流程,将所述子流程向对应的子系统发送,以使所述子系统对子流程进行处理之后,还包括:接收子系统反馈的响应消息;将所述响应消息格式化,得到响应报文;将所述响应报文向所述调用系统发送。一种分布式事务的流程保障装置,包括:收发单元,用于接收调用系统发送的处理请求;配置单元,用于根据所述处理请求确定主流程以及N个子流程,N≥1;所述收发单元,还用于针对所述N个子流程中的任一子流程,将所述子流程向对应的子系统发送,以使所述子系统对子流程进行处理;监控单元,用于对N个子流程的处理过程进行监控,当任一子流程的处理过程出现异常时,根据异常类型、所述主流程的类型以及所述子流程的类型确定对应的异常处理策略;异常处理单元,用于根据所述异常处理策略对子流程进行异常处理,所述异常处理包括对已经处理成功的子流程执行非对称反向操作,所述非对称反向操作为执行反向子流程,所述反向子流程与所述已经处理的子流程非对称。一种可选的实施例中,所述N个子流程中包括异步子流程;所述收发单元,还用于:针对所述异步子流程,以设置的频率向所述异步子流程对应的异步子系统发送结果查询请求,直至接收到所述异步子系统反馈的处理结果。一种可选的实施例中,所述异常处理单元,用于:针对所述异步子流程,执行重试处理。一种可选的实施例中,所述监控单元,用于对所述主流程以及每个子流程的处理时间进行监控,若所述主流程和/或任一子流程的处理时间超过对应的时间阈值,则确定出现超时类异常;所述异常处理单元,用于针对异步子流程出现超时类异常,则对所述异步子流程执行重试处理;针对主流程和/或同步子流程出现超时类异常,向所述调用系统反馈处理过程超时,并确定超时子流程的处理状态;若所述超时子流程的处理状态明确,则对已处理成功的子流程执行非对称反向操作;若所述超时子流程的处理状态不明确,则对所述主流程转批量异步处理。一种可选的实施例中,所述异常处理单元,用于:间隔预定时间段后,向所述超时子流程对应的子系统发送结果查询请求;若接收到所述子系统发送的处理成功结果,则对所述超时子流程以及所述超时子流程之前的子流程执行非对称反向操作;若接收到所述子系统发送的处理失败结果,则对所述超时子流程之前的子流程执行非对称反向操作;若接收到所述子系统发送的处理结果不明确反馈,则执行所述间隔预定时间段后,向所述超时子流程对应的子系统发送结果查询请求的步骤。一种可选的实施例中,所述收发单元,用于:统计接收到的处理请求的数量;若所述处理请求的数量大于流量预警值,则向所述调用系统发送预警消息,并控制向所述调用系统反馈响应报文的时间。一种可选的实施例中,所述收发单元,用于:接收子系统反馈的响应消息;将所述响应消息格式化,得到响应报文;将所述响应报文向所述调用系统发送。本专利技术实施例还提供一种电子设备,包括:至少一个处理器;以及,与所述至少一个处理器通信连接的存储器;其中,所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行如上所述的方法。本专利技术实施例还提供一种非暂态计算机可读存储介质,所述非暂态计算机可读存储介质存储计算机指令,所述计算机指令用于使所述计算机执行如上所述的方法。本专利技术实施例中,接收调用系统发送的处理请求,对处理请求进行解析,匹配出对应的主流程和N个子流程。对于N个子流程,依次将子流程向对应子系统发送,以使子系统对子流程进行处理,同时对N个子流程的处理过程进行监控,当任一子流程的处理过程出现异常时,根据异常类型、主流程类型以及子流程类型确定对应的异常处理策略。根据异常处理策略对子流程进行异常处理,其中,异常处理包括对已经处理成本文档来自技高网...

【技术保护点】
1.一种分布式事务的流程保障方法,其特征在于,包括:接收调用系统发送的处理请求;根据所述处理请求确定主流程以及N个子流程,N≥1;针对所述N个子流程中的任一子流程,将所述子流程向对应的子系统发送,以使所述子系统对子流程进行处理;对N个子流程的处理过程进行监控,当任一子流程的处理过程出现异常时,根据异常类型、所述主流程的类型以及所述子流程的类型确定对应的异常处理策略;根据所述异常处理策略对子流程进行异常处理,所述异常处理包括对已经处理成功的子流程执行非对称反向操作,所述非对称反向操作为执行反向子流程,所述反向子流程与所述已经处理的子流程非对称。

【技术特征摘要】
1.一种分布式事务的流程保障方法,其特征在于,包括:接收调用系统发送的处理请求;根据所述处理请求确定主流程以及N个子流程,N≥1;针对所述N个子流程中的任一子流程,将所述子流程向对应的子系统发送,以使所述子系统对子流程进行处理;对N个子流程的处理过程进行监控,当任一子流程的处理过程出现异常时,根据异常类型、所述主流程的类型以及所述子流程的类型确定对应的异常处理策略;根据所述异常处理策略对子流程进行异常处理,所述异常处理包括对已经处理成功的子流程执行非对称反向操作,所述非对称反向操作为执行反向子流程,所述反向子流程与所述已经处理的子流程非对称。2.如权利要求1所述的方法,其特征在于,所述N个子流程中包括异步子流程;所述针对所述N个子流程中的任一子流程,将所述子流程向对应的子系统发送,以使所述子系统对子流程进行处理之后,还包括:若所述子流程为异步子流程,则以设置的频率向所述异步子流程对应的异步子系统发送结果查询请求,直至接收到所述异步子系统反馈的处理结果。3.如权利要求2所述的方法,其特征在于,所述根据所述异常处理策略对子流程进行异常处理,包括:针对所述异步子流程,执行重试处理。4.如权利要求1所述的方法,其特征在于,所述对N个子流程的处理过程进行监控,包括:对所述主流程以及每个子流程的处理时间进行监控,若所述主流程和/或任一子流程的处理时间超过对应的时间阈值,则确定出现超时类异常;所述根据所述异常处理策略对子流程进行异常处理,包括:针对异步子流程出现超时类异常,则对所述异步子流程执行重试处理;针对主流程和/或同步子流程出现超时类异常,向所述调用系统反馈处理过程超时,并确定超时子流程的处理状态;若所述超时子流程的处理状态明确,则对已处理成功的子流程执行非对称反向操作;若所述超时子流程的处理状态不明确,则对所述主流程转批量异步处理。5.如权利要求4所述的方法,其特征在于,所述若所述超时子流程的处理状态不明确,则对所述主流程转批量异步处理,包括:间隔预定时间段后,向所述超时子流程对应的子系统发送结果查询请求;若接收到所述子系统发送的处理成功结果,则对所述超时子流程以及所述超时子流程之前的子流程执行非对称反向操作;若接收到所述子系统发送的处理失败结果,则对所述超时子流程之前的子流程执行非对称反向操作;若接收到所述子系统发送的处理结果不明确反馈,则执行所述间隔预定时间段后,向所述超时子流程对应的子系统发送结果查询请求的步骤。6.如权利要求1所述的方法,其特征在于,所述接收调用系统发送的处理请求,包括:统计接收到的处理请求的数量;若所述处理请求的数量大于流量预警值,则向所述调用系统发送预警消息,并控制向所述调用系统反馈响应报文的时间。7.如权利要求1至6任一项所述的方法,其特征在于,所述针对所述N个子流程中的任一子流程,将所述子流程向对应的子系统发送,以使所述子系统对子流程进行处理之后,还包括:接收子系统反馈的响应消息;将所述响应消息格式化,得到响应报文;将所述响应报文向所述调用系统发送。8.一种分布式事务的流程保障装置,其特征在于,包括:收发单元,用于接收调用...

【专利技术属性】
技术研发人员:张兵夏勇
申请(专利权)人:深圳前海微众银行股份有限公司
类型:发明
国别省市:广东,44

网友询问留言 已有0条评论
  • 还没有人留言评论。发表了对其他浏览者有用的留言会获得科技券。

1