CN110599305A - 业务处理方法、装置及存储介质 - Google Patents
业务处理方法、装置及存储介质 Download PDFInfo
- Publication number
- CN110599305A CN110599305A CN201910872246.0A CN201910872246A CN110599305A CN 110599305 A CN110599305 A CN 110599305A CN 201910872246 A CN201910872246 A CN 201910872246A CN 110599305 A CN110599305 A CN 110599305A
- Authority
- CN
- China
- Prior art keywords
- business process
- target
- exception handling
- target business
- rollback
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Pending
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q30/00—Commerce
- G06Q30/06—Buying, selling or leasing transactions
- G06Q30/0601—Electronic shopping [e-shopping]
- G06Q30/0633—Lists, e.g. purchase orders, compilation or processing
- G06Q30/0635—Processing of requisition or of purchase orders
Landscapes
- Business, Economics & Management (AREA)
- Accounting & Taxation (AREA)
- Finance (AREA)
- Development Economics (AREA)
- Economics (AREA)
- Marketing (AREA)
- Strategic Management (AREA)
- Physics & Mathematics (AREA)
- General Business, Economics & Management (AREA)
- General Physics & Mathematics (AREA)
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Management, Administration, Business Operations System, And Electronic Commerce (AREA)
Abstract
本申请公开了一种业务处理方法、装置及存储介质,属于数据处理领域。所述方法包括:从业务处理模型的配置信息中确定目标业务流程的业务流程方法,基于目标业务流程的业务流程方法,运行目标业务流程;当检测到目标业务流程运行异常时,从业务处理模型的配置信息中确定目标业务流程的异常处理方式,以及与目标业务流程的异常处理方式对应的异常处理方法,异常处理方法为业务流程方法或回滚方法;调用异常处理方法,基于目标业务流程的运行信息,执行调用的异常处理方法。本申请提供了一种通用的业务处理模型,能够配置任一业务流程的业务流程方法、回滚方法和异常处理方式,避免了定制化业务系统仅限于特定业务场景使用导致的通用性较低的问题。
Description
技术领域
本申请涉及数据处理领域,特别涉及一种业务处理方法、装置及存储介质。
背景技术
随着网络技术的快速发展以及人们对便捷生活的需求,目前出现了能够应对各种业务场景的业务处理系统。比如,金融产品领域的电商系统能够为用户提供商品搜索业务、下单业务和退单业务等等。
相关技术中,针对不同的业务场景,需要定制不同的业务处理系统,以通过定制的业务处理系统实现定制化的业务处理方案。例如,为了解决退单业务场景中操作时间冗长的问题,需要定制一种退单处理系统,该退单处理系统包括同步服务器、异步服务器和操作平台。其中,同步服务器包括接收端和处理端,处理端串联设置多个面向用户的单元,异步服务器设置多个面向商户的单元。同步服务器的接收端接收用户的退单操作,生成用户订单锁定信息,并发送到同步服务器的处理端,处理端依次根据多个面向用户的单元各自的功能进行面向用户的信息处理,并在处理结束后生成订单撤销指令,发送至操作平台。同步服务器生成订单撤销指令之后,向异步服务器发送后台处理指令,异步服务器依次根据多个面向商户的单元各自的功能进行面向商户的信息处理,并且在处理结束后校验整个处理过程。
但是,通过定制的业务处理系统实现定制化的业务处理方案的业务处理方式,仅能针对某一个固定的业务场景下的具体系统使用,通用性较低。
发明内容
本申请实施例提供了一种业务处理方法、装置及存储介质,可以用于解决相关技术中存在的通过定制的业务处理系统实现定制化的业务处理方案的业务处理方式,仅能针对某一个固定的业务场景下的具体系统使用,通用性较低的问题。所述技术方案如下:
一方面,提供了一种业务处理方法,所述方法包括:
从业务处理模型的配置信息中确定目标业务流程的业务流程方法,所述业务处理模型用于配置任一业务流程的业务流程方法、回滚方法和异常处理方式,所述异常处理方式包括回滚或补偿;
基于所述目标业务流程的业务流程方法,运行所述目标业务流程;
当检测到所述目标业务流程运行异常时,从所述业务处理模型的配置信息中确定所述目标业务流程的异常处理方式,以及与所述目标业务流程的异常处理方式对应的异常处理方法,所述异常处理方法为所述目标业务流程的业务流程方法或回滚方法;
调用所述异常处理方法,基于所述目标业务流程的运行信息,执行调用的异常处理方法。
可选地,所述业务处理模型包括业务流程模型、异常配置项和配置入口,所述配置入口用于通过在所述业务流程模型中注解业务流程方法参数和回滚方法参数,配置任一业务流程的业务流程方法和回滚方法,且所述配置入口用于在所述异常配置项中配置任一业务流程的异常处理方式。
可选地,所述业务处理模型还包括业务流程步骤模型,所述配置入口用于通过在所述业务流程步骤模型中注解业务流程步骤方法参数和回滚方法参数,配置任一业务流程包括的各个业务流程步骤的业务流程步骤方法和回滚方法。
可选地,所述基于所述目标业务流程的业务流程方法,运行所述目标业务流程之前,还包括:
从所述业务处理模型的配置信息中确定所述目标业务流程包括的多个业务流程步骤的业务流程步骤方法;
所述基于所述目标业务流程的业务流程方法,运行所述目标业务流程,包括:
调用所述目标业务流程的业务流程方法;
执行调用的业务流程方法,通过执行的业务流程方法,依次调用所述目标业务流程包括的多个业务流程步骤的业务流程步骤方法;
依次执行调用的所述多个业务流程步骤的业务流程步骤方法。
可选地,所述从所述业务处理模型的配置信息中确定与所述目标业务流程的异常处理方式对应的异常处理方法,包括:
若所述目标业务流程的异常处理方式为回滚,则从所述业务处理模型的配置信息中确定所述目标业务流程的回滚方法,将所述目标业务流程的回滚方法,作为与所述目标业务流程的异常处理方式对应的异常处理方法;
所述调用所述异常处理方法,基于所述目标业务流程的运行信息,执行调用的异常处理方法,包括:
从所述目标业务流程的运行信息中,确定所述目标业务流程的流程参数;
调用所述目标业务流程的回滚方法,将所述流程参数作为所述目标业务流程的回滚方法的入参,执行所述目标业务流程的回滚方法。
可选地,所述业务处理模型还用于配置任一业务流程包括的各个业务流程步骤的回滚方法,所述方法还包括:
从所述目标业务流程包括的多个业务流程步骤中,确定运行异常的业务流程步骤,以及步骤顺序位于运行异常的业务流程步骤之前的目标业务流程步骤;
从所述业务处理模型的配置信息中,确定所述目标业务流程步骤的回滚方法;
从所述目标业务流程的运行信息中,确定所述目标业务流程步骤的步骤参数;
调用所述目标业务流程步骤的回滚方法,将所述目标业务流程步骤的步骤参数作为所述目标业务流程步骤的回滚方法的入参,执行调用的所述目标业务流程步骤的回滚方法。
可选地,所述从所述业务处理模型的配置信息中确定与所述目标业务流程的异常处理方式对应的异常处理方法,包括:
若所述目标业务流程的异常处理方式为补偿,则从所述业务处理模型的配置信息中确定所述目标业务流程的业务流程方法,将所述目标业务流程的业务流程方法,作为与所述目标业务流程的异常处理方式对应的异常处理方法;
所述调用所述异常处理方法,基于所述目标业务流程的运行信息,执行调用的异常处理方法,包括:
从所述目标业务流程的运行信息中,确定所述目标业务流程的流程参数;
调用所述目标业务流程的业务流程方法,将所述流程参数作为所述目标业务流程的业务流程方法的入参,执行调用的所述目标业务流程的业务流程方法。
可选地,所述业务处理模型还用于配置任一业务流程包括的各个业务流程步骤的业务流程步骤方法;
所述执行调用的所述目标业务流程的业务流程方法之前,还包括:
从所述业务处理模型的配置信息中,确定所述目标业务流程包括的多个业务流程步骤的业务流程步骤方法;
从所述目标业务流程的运行信息中,确定所述目标业务流程包括的所述多个业务流程步骤的步骤参数;
所述执行调用的所述目标业务流程的业务流程方法之后,还包括
通过执行的业务流程方法,依次调用所述目标业务流程包括的多个业务流程步骤的业务流程步骤方法;
将所述多个业务流程步骤中各个业务流程步骤的步骤参数作为各个业务流程步骤的业务流程步骤方法的入参,依次执行所述多个业务流程步骤的业务流程步骤方法。
可选地,所述基于所述目标业务流程的运行信息,执行调用的异常处理方法之后,还包括:
若所述异常处理方法执行失败且所述异常处理方法的已执行次数小于次数阈值,则重复执行所述异常处理方法;
若所述异常处理方法执行失败且所述异常处理方法的已执行次数等于所述次数阈值,则进行异常提醒。
另一方面,提供了一种业务处理装置,所述装置包括:
第一确定模块,用于从业务处理模型的配置信息中确定目标业务流程的业务流程方法,所述业务处理模型用于配置任一业务流程的业务流程方法、回滚方法和异常处理方式,所述异常处理方式包括回滚或补偿;
运行模块,用于基于所述目标业务流程的业务流程方法,运行所述目标业务流程;
第二确定模块,用于当检测到所述目标业务流程运行异常时,从所述业务处理模型的配置信息中确定所述目标业务流程的异常处理方式,以及与所述目标业务流程的异常处理方式对应的异常处理方法,所述异常处理方法为所述目标业务流程的业务流程方法或回滚方法;
执行模块,用于调用所述异常处理方法,基于所述目标业务流程的运行信息,执行调用的异常处理方法。
可选地,所述业务处理模型包括业务流程模型、异常配置项和配置入口,所述配置入口用于通过在所述业务流程模型中注解业务流程方法参数和回滚方法参数,配置任一业务流程的业务流程方法和回滚方法,且所述配置入口用于在所述异常配置项中配置任一业务流程的异常处理方式。
可选地,所述业务处理模型还包括业务流程步骤模型,所述配置入口用于通过在所述业务流程步骤模型中注解业务流程步骤方法参数和回滚方法参数,配置任一业务流程包括的各个业务流程步骤的业务流程步骤方法和回滚方法。
可选地,所述装置还包括:
第三确定模块,用于从所述业务处理模型的配置信息中确定所述目标业务流程包括的多个业务流程步骤的业务流程步骤方法;
所述运行模块用于:
调用所述目标业务流程的业务流程方法;
执行调用的业务流程方法,通过执行的业务流程方法,依次调用所述目标业务流程包括的多个业务流程步骤的业务流程步骤方法;
依次执行调用的所述多个业务流程步骤的业务流程步骤方法。
可选地,所述第二确定模块用于:
若所述目标业务流程的异常处理方式为回滚,则从所述业务处理模型的配置信息中确定所述目标业务流程的回滚方法,将所述目标业务流程的回滚方法,作为与所述目标业务流程的异常处理方式对应的异常处理方法;
所述执行模块用于:
从所述目标业务流程的运行信息中,确定所述目标业务流程的流程参数;
调用所述目标业务流程的回滚方法,将所述流程参数作为所述目标业务流程的回滚方法的入参,执行所述目标业务流程的回滚方法。
可选地,所述业务处理模型还用于配置任一业务流程包括的各个业务流程步骤的回滚方法;所述装置还包括第四确定模块,用于:
从所述目标业务流程包括的多个业务流程步骤中,确定运行异常的业务流程步骤,以及步骤顺序位于运行异常的业务流程步骤之前的目标业务流程步骤;
从所述业务处理模型的配置信息中,确定所述目标业务流程步骤的回滚方法;
从所述目标业务流程的运行信息中,确定所述目标业务流程步骤的步骤参数;
所述执行模块还用于:
调用所述目标业务流程步骤的回滚方法,将所述目标业务流程步骤的步骤参数作为所述目标业务流程步骤的回滚方法的入参,执行调用的所述目标业务流程步骤的回滚方法。
可选地,所述第二确定模块用于:
若所述目标业务流程的异常处理方式为补偿,则从所述业务处理模型的配置信息中确定所述目标业务流程的业务流程方法,将所述目标业务流程的业务流程方法,作为与所述目标业务流程的异常处理方式对应的异常处理方法;
所述执行模块用于:
从所述目标业务流程的运行信息中,确定所述目标业务流程的流程参数;
调用所述目标业务流程的业务流程方法,将所述流程参数作为所述目标业务流程的业务流程方法的入参,执行调用的所述目标业务流程的业务流程方法。
可选地,所述业务处理模型还用于配置任一业务流程包括的各个业务流程步骤的业务流程步骤方法;所述装置还包括第五确定模块,用于:
从所述业务处理模型的配置信息中,确定所述目标业务流程包括的多个业务流程步骤的业务流程步骤方法;
从所述目标业务流程的运行信息中,确定所述目标业务流程包括的所述多个业务流程步骤的步骤参数;
所述执行模块还用于:
通过执行的业务流程方法,依次调用所述目标业务流程包括的多个业务流程步骤的业务流程步骤方法;
将所述多个业务流程步骤中各个业务流程步骤的步骤参数作为各个业务流程步骤的业务流程步骤方法的入参,依次执行所述多个业务流程步骤的业务流程步骤方法。
可选地,所述装置还包括报警模块;
所述执行模块,还用于若所述异常处理方法执行失败且所述异常处理方法的已执行次数小于次数阈值,则重复执行所述异常处理方法;
所述报警模块,用于若所述异常处理方法执行失败且所述异常处理方法的已执行次数等于所述次数阈值,则进行异常提醒。
另一方面,提供了一种业务处理装置,所述装置包括:
一个或多个处理器;
用于存储所述一个或多个处理器可执行指令的一个或多个存储器;
其中,所述一个或多个处理器被配置为执行上述任一种业务处理方法。
另一方面,提供了一种非临时性计算机可读存储介质,所述存储介质上存储有指令,所述指令被处理器执行时实现上述任一种业务处理方法的步骤。
另一方面,提供了一种计算机程序产品,当所述计算机程序产品在计算机上运行时,使得计算机执行上述任一种业务处理方法的步骤。
本申请实施例提供的技术方案带来的有益效果是:
本申请实施例提供了一种通用的业务处理模型,通过该业务处理模型能够配置任一业务流程的业务流程方法、回滚方法和异常处理方式,使得任一业务系统均能够通过该业务处理模型实现任一业务,通用性较高,避免了定制化业务系统仅限于特定业务场景使用导致的通用性较低的问题。
附图说明
为了更清楚地说明本申请实施例中的技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本申请的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1是本申请实施例提供的一种业务流程模型的逻辑示意图;
图2是本申请实施例提供的一种业务流程步骤模型的逻辑示意图;
图3是本申请实施例提供的一种业务处理方法的流程图;
图4是本申请实施例提供的一种业务处理装置的结构框图;
图5是本申请实施例提供的一种业务处理装置的结构示意图。
具体实施方式
为使本申请的目的、技术方案和优点更加清楚,下面将结合附图对本申请实施方式作进一步地详细描述。
在对本申请实施例进行详细地解释说明之前,先对本申请实施例的应用场景予以说明。
本申请实施例提供了一种通用的业务处理模型以及基于该业务处理模型的柔性事务的处理流程。本申请实施例提供的业务处理模型和业务处理方法可以应用于任一业务场景中,可选地,应用于金融业务场景中的金融产品系统中,或者应用于分布式微服务场景下的各种金融产品系统中。而且,本申请实施例提供的方法并不是针对单独的业务场景下的具体系统使用,而是在任一业务处理系统中通用的一种工作方法,而且可以在低成本,不依赖外部组件的情况下实现柔性业务。
接下来,对本申请实施例的实施环境进行介绍。
本申请实施例提供了一种业务处理模型,该业务处理模型是一种通用性较高的工具组件,该工具组件是一种可编程组件,以供编程人员进行开发使用。通过该业务处理模型,编程人员可以配置任一业务流程的业务流程方法、回滚方法和异常处理方式。
可选地,该业务处理模型包括业务流程模型和异常配置项,业务流程模型用于配置业务流程方法,异常配置项用于配置业务流程的异常处理方式,异常处理方式包括回滚或补偿。对于异常处理方式为回滚的,异常配置项还用于配置对应的回滚方法。进一步地,该业务处理模型还包括业务流程步骤模型,异常配置项还用于配置业务流程步骤的异常处理方式。
示例的,如图1所示,业务流程模型包括业务流程方法和对应的回滚方法,如图2所示,业务流程步骤模型包括业务流程步骤方法和对应的回滚方法。
业务流程模型的业务流程方法,负责调用各个业务流程步骤模型的业务流程步骤方法,来完成串联各个微服务的调用,完成业务流程。
业务流程模型的回滚方法,负责在业务流程发生回滚时被调用,以完成对应业务流程的业务回滚操作。
业务流程步骤模型的业务流程步骤方法,负责完成业务流程中的一个单独的步骤,例如调用其中一个下游服务并完成逻辑判断等。
业务流程步骤模型的回滚方法,负责在业务流程发生回滚时,被业务流程模型调用,以完成该业务流程步骤对应的回滚方法。
异常配置项用于配置业务流程的异常处理方式:回滚或补偿。对于异常处理方式为回滚的,该业务处理模型将调用业务流程的回滚方法以及该业务流程对应的各个业务流程步骤的回滚方法。对于异常处理方式为补偿的,该业务处理模型将调用业务流程的业务流程方法。
可选地,该业务处理模型包括业务流程模型、异常配置项和配置入口,配置入口用于通过在业务流程模型中注解业务流程方法参数和回滚方法参数,配置任一业务流程的业务流程方法和回滚方法,配置入口用于在异常配置项中配置任一业务流程的异常处理方式。可选地,该业务处理模型还包括业务流程步骤模型,配置入口用于通过在业务流程步骤模型中注解业务流程步骤方法参数和回滚方法参数,配置任一业务流程包括的各个业务流程步骤的业务流程步骤方法和回滚方法。
本申请实施例中,使用方可以根据需要实现该业务处理模型所提供的业务流程模型的业务流程方法和回滚方法,以及业务流程步骤模型中的业务流程步骤方法和回滚方法,并根据使用方自己的业务特点,配置发生异常时业务处理模型的异常处理方式,异常处理方式包括回滚或补偿。
另外,该业务处理模型还可以在业务流程执行的过程中,记录业务流程的运行信息。比如可以通过数据库日志表记录业务流程的运行信息。该运行信息包括业务流程配置的异常处理方式、业务流程的执行状态、业务流程的流程参数、业务流程步骤的执行状态、业务流程步骤的步骤参数、业务流程与业务流程步骤之间的映射关系和业务流程步骤的步骤序号中的一种或多种。
其中,业务流程配置的异常处理方式为业务流程发生异常时的处理方式,包括:回滚或补偿。业务流程的执行状态包括:初始状态、执行成功、执行失败、回滚成功或回滚失败等。业务流程的流程参数是指业务流程执行时的入参,可以通过序列化的方式进行存储。业务流程步骤的执行状态包括:初始状态、执行成功、执行失败、回滚成功或回滚失败等。业务流程步骤的步骤参数是指业务流程步骤执行时的入参,可以通过序列化的方式进行存储。业务流程与业务流程步骤之间的映射关系用于表示业务流程步骤属于哪个业务流程。业务流程步骤的步骤序号用于指示业务流程步骤的执行顺序,步骤序号一般从1开始。
作为一个示例,业务流程模型在业务流程执行时,可以通过程序切面获取业务流程的流程参数以及业务流程步骤的步骤参数等运行信息,并将运行信息记录到数据库日志表中。示例的,数据库日志表中记录的运行信息可以如下表1所示。
表1
需要说明的是,本申请实施例仅是以表1所示的运行信息为例进行说明,但是表1中运行信息的内容并不构成对运行信息的限定。
图3是本申请实施例提供的一种业务处理方法的流程图,该方法应用于计算机设备中,该计算机设备可以为终端或服务器,该计算机设备中配置有业务处理模型,该方法基于计算机设备中的业务处理模型实现。参见图3,该方法如下步骤:
步骤301:从业务处理模型的配置信息中确定目标业务流程的业务流程方法,业务处理模型用于配置任一业务流程的业务流程方法、回滚方法和异常处理方式,异常处理方式包括回滚或补偿。
其中,目标业务流程可以为使用方所要实现的任一业务流程,比如金融产品系统的任一业务流程。
目标业务流程的业务流程方法可以由开发人员预先在该业务处理模型的业务流程模型中进行配置,而在要执行目标业务流程时,即可自动通过该业务处理模型,获取针对目标业务流程配置的业务流程方法。
步骤302:基于目标业务流程的业务流程方法,运行目标业务流程。
可选地,目标业务流程可以包括多个业务流程步骤,各个业务流程步骤的步骤方法可以预先在业务处理模型的业务流程步骤模型中进行配置,本申请实施例中,可以通过调用和执行目标业务流程包括的多个业务流程步骤的业务流程步骤方法,来运行目标业务流程。
可选地,基于目标业务流程的业务流程方法,运行目标业务流程的操作包括:从业务处理模型的配置信息中确定目标业务流程包括的多个业务流程步骤的业务流程步骤方法;调用目标业务流程的业务流程方法;执行调用的业务流程方法,通过执行的业务流程方法,依次调用目标业务流程包括的多个业务流程步骤的业务流程步骤方法;依次执行调用的多个业务流程步骤的业务流程步骤方法。
可选地,可以根据目标业务流程和业务流程步骤的映射关系,从业务处理模型的配置信息中确定目标业务流程包括的多个业务流程步骤,以及每个业务流程步骤的业务流程步骤方法。
步骤303:当检测到目标业务流程运行异常时,从业务处理模型的配置信息中确定目标业务流程的异常处理方式,以及与该异常处理方式对应的异常处理方法,异常处理方法为目标业务流程的业务流程方法或回滚方法。
本申请实施例中,业务处理模型可以在目标业务流程发生异常时,根据使用方的配置动态决定应该是回滚还是应用补偿。根据配置的异常处理方式的不同,可以包括以下两种实现方式:
第一种实现方式:若目标业务流程的异常处理方式为回滚,则从业务处理模型的配置信息中获取配置的回滚方法。
若目标业务流程的异常处理方式为回滚,则从业务处理模型的配置信息中确定目标业务流程的回滚方法,将目标业务流程的回滚方法,作为与目标业务流程的异常处理方式对应的异常处理方法。
第二种实现方式:若目标业务流程的异常处理方式为补偿,则从业务处理模型的配置信息中获取配置的业务流程方法。
若目标业务流程的异常处理方式为补偿,则从该业务处理模型的配置信息中确定该目标业务流程的业务流程方法,将该目标业务流程的业务流程方法,作为与该目标业务流程的异常处理方式对应的异常处理方法。
步骤304:调用该异常处理方法,基于目标业务流程的运行信息,执行调用的异常处理方法。
本申请实施例中,根据异常处理方式的不同,进行异常处理的操作可以包括如下两种实现方式:
第一种实现方式:若目标业务流程的异常处理方式为回滚,则根据获取的回滚方法对目标业务流程进行回滚。
若目标业务流程的异常处理方式为回滚,则从目标业务流程的运行信息中,确定目标业务流程的流程参数;调用目标业务流程的回滚方法,将流程参数作为目标业务流程的回滚方法的入参,执行目标业务流程的回滚方法。
可选地,该业务处理模型还用于配置任一业务流程包括的各个业务流程步骤的回滚方法,在对目标业务流程进行回滚时,还需要对步骤顺序位于运行异常的业务流程步骤之前的目标业务流程步骤进行回滚。
可选地,回滚过程还包括:从目标业务流程包括的多个业务流程步骤中,确定运行异常的业务流程步骤,以及步骤顺序位于运行异常的业务流程步骤之前的目标业务流程步骤;从业务处理模型的配置信息中,确定目标业务流程步骤的回滚方法;从目标业务流程的运行信息中,确定目标业务流程步骤的步骤参数;调用目标业务流程步骤的回滚方法,将目标业务流程步骤的步骤参数作为该目标业务流程步骤的回滚方法的入参,执行调用的该目标业务流程步骤的回滚方法。
可选地,若目标业务流程回滚成功,还可以将目标业务流程的执行状态以及对应的业务流程步骤的执行状态设置为回滚成功。若目标业务流程回滚失败,还可以将目标业务流程的执行状态以及对应的业务流程步骤的执行状态设置为回滚失败。
第二种实现方式:若目标业务流程的异常处理方式为补偿,则根据获取的业务流程方法对目标业务流程进行补偿。
若目标业务流程的异常处理方式为补偿,则从目标业务流程的运行信息中,确定目标业务流程的流程参数;调用目标业务流程的业务流程方法,将该流程参数作为目标业务流程的业务流程方法的入参,执行调用的该目标业务流程的业务流程方法。
可选地,该业务处理模型还用于配置任一业务流程包括的各个业务流程步骤的业务流程步骤方法,对目标业务流程进行补偿时,还需要对目标业务流程包括的各个业务流程步骤进行补偿。
可选地,补偿过程还包括:从该业务处理模型的配置信息中,确定目标业务流程包括的多个业务流程步骤的业务流程步骤方法;从目标业务流程的运行信息中,确定目标业务流程包括的多个业务流程步骤的步骤参数;通过执行的业务流程方法,依次调用目标业务流程包括的多个业务流程步骤的业务流程步骤方法;将该多个业务流程步骤中各个业务流程步骤的步骤参数作为各个业务流程步骤的业务流程步骤方法的入参,依次执行该多个业务流程步骤的业务流程步骤方法。
可选地,若目标业务流程补偿成功,还可以将目标业务流程的执行状态以及对应的业务流程步骤的执行状态设置为补偿成功。若目标业务流程补偿失败,还可以将目标业务流程的执行状态以及对应的业务流程步骤的执行状态设置为补偿失败。
可选地,基于目标业务流程的运行信息,执行调用的异常处理方法之后,还包括:若异常处理方法执行失败且异常处理方法的已执行次数小于次数阈值,则重复执行该异常处理方法;若该异常处理方法执行失败且该异常处理方法的已执行次数等于该次数阈值,则进行异常提醒。
可选地,次数阈值由业务处理模型默认设置,或者由开发人员预先设置,本申请实施例对此不做限定。示例的,次数阈值为3。可选地,该异常提醒用于提醒人工介入进行处理。可选地,若该异常处理方法执行失败且该异常处理方法的已执行次数等于该次数阈值,可以将该异常处理过程记录在异常日志中,以通过异常日志进行异常提醒。
作为一个示例,若异常处理方式对应的回滚或补偿流程没有成功,则业务处理模型可以进行重试,继续调用业务流程的回滚方法或补偿方法。如果重试3次依然识别,则可以将异常记录在异常日志中,以提示通过人工介入进行处理。
本申请实施例提供了一种通用的业务处理模型,通过该业务处理模型能够配置任一业务流程的业务流程方法、回滚方法和异常处理方式,使得任一业务系统均能够通过该业务处理模型实现任一业务,通用性较高,避免了定制化业务系统仅限于特定业务场景使用导致的通用性较低的问题。
图4是本申请实施例提供的一种业务处理装置的结构框图,如图4所示,该该装置包括第一确定模块401、运行模块402、第二确定模块403和执行模块404。
第一确定模块401,用于从业务处理模型的配置信息中确定目标业务流程的业务流程方法,所述业务处理模型用于配置任一业务流程的业务流程方法、回滚方法和异常处理方式,所述异常处理方式包括回滚或补偿;
运行模块402,用于基于所述目标业务流程的业务流程方法,运行所述目标业务流程;
第二确定模块403,用于当检测到所述目标业务流程运行异常时,从所述业务处理模型的配置信息中确定所述目标业务流程的异常处理方式,以及与所述目标业务流程的异常处理方式对应的异常处理方法,所述异常处理方法为所述目标业务流程的业务流程方法或回滚方法;
执行模块404,用于调用所述异常处理方法,基于所述目标业务流程的运行信息,执行调用的异常处理方法。
可选地,所述业务处理模型包括业务流程模型、异常配置项和配置入口,所述配置入口用于通过在所述业务流程模型中注解业务流程方法参数和回滚方法参数,配置任一业务流程的业务流程方法和回滚方法,且所述配置入口用于在所述异常配置项中配置任一业务流程的异常处理方式。
可选地,所述业务处理模型还包括业务流程步骤模型,所述配置入口用于通过在所述业务流程步骤模型中注解业务流程步骤方法参数和回滚方法参数,配置任一业务流程包括的各个业务流程步骤的业务流程步骤方法和回滚方法。
可选地,所述装置还包括:
第三确定模块,用于从所述业务处理模型的配置信息中确定所述目标业务流程包括的多个业务流程步骤的业务流程步骤方法;
所述运行模块402用于:
调用所述目标业务流程的业务流程方法;
执行调用的业务流程方法,通过执行的业务流程方法,依次调用所述目标业务流程包括的多个业务流程步骤的业务流程步骤方法;
依次执行调用的所述多个业务流程步骤的业务流程步骤方法。
可选地,所述第二确定模块用于:
若所述目标业务流程的异常处理方式为回滚,则从所述业务处理模型的配置信息中确定所述目标业务流程的回滚方法,将所述目标业务流程的回滚方法,作为与所述目标业务流程的异常处理方式对应的异常处理方法;
所述执行模块404用于:
从所述目标业务流程的运行信息中,确定所述目标业务流程的流程参数;
调用所述目标业务流程的回滚方法,将所述流程参数作为所述目标业务流程的回滚方法的入参,执行所述目标业务流程的回滚方法。
可选地,所述业务处理模型还用于配置任一业务流程包括的各个业务流程步骤的回滚方法;所述装置还包括第四确定模块,用于:
从所述目标业务流程包括的多个业务流程步骤中,确定运行异常的业务流程步骤,以及步骤顺序位于运行异常的业务流程步骤之前的目标业务流程步骤;
从所述业务处理模型的配置信息中,确定所述目标业务流程步骤的回滚方法;
从所述目标业务流程的运行信息中,确定所述目标业务流程步骤的步骤参数;
所述执行模块404还用于:
调用所述目标业务流程步骤的回滚方法,将所述目标业务流程步骤的步骤参数作为所述目标业务流程步骤的回滚方法的入参,执行调用的所述目标业务流程步骤的回滚方法。
可选地,所述第二确定模块403用于:
若所述目标业务流程的异常处理方式为补偿,则从所述业务处理模型的配置信息中确定所述目标业务流程的业务流程方法,将所述目标业务流程的业务流程方法,作为与所述目标业务流程的异常处理方式对应的异常处理方法;
所述执行模块404用于:
从所述目标业务流程的运行信息中,确定所述目标业务流程的流程参数;
调用所述目标业务流程的业务流程方法,将所述流程参数作为所述目标业务流程的业务流程方法的入参,执行调用的所述目标业务流程的业务流程方法。
可选地,所述业务处理模型还用于配置任一业务流程包括的各个业务流程步骤的业务流程步骤方法;所述装置还包括第五确定模块,用于:
从所述业务处理模型的配置信息中,确定所述目标业务流程包括的多个业务流程步骤的业务流程步骤方法;
从所述目标业务流程的运行信息中,确定所述目标业务流程包括的所述多个业务流程步骤的步骤参数;
所述执行模块404还用于:
通过执行的业务流程方法,依次调用所述目标业务流程包括的多个业务流程步骤的业务流程步骤方法;
将所述多个业务流程步骤中各个业务流程步骤的步骤参数作为各个业务流程步骤的业务流程步骤方法的入参,依次执行所述多个业务流程步骤的业务流程步骤方法。
可选地,所述装置还包括报警模块;
所述执行模块404,还用于若所述异常处理方法执行失败且所述异常处理方法的已执行次数小于次数阈值,则重复执行所述异常处理方法;
所述报警模块,用于若所述异常处理方法执行失败且所述异常处理方法的已执行次数等于所述次数阈值,则进行异常提醒。
本申请实施例提供了一种通用的业务处理模型,通过该业务处理模型能够配置任一业务流程的业务流程方法、回滚方法和异常处理方式,使得任一业务系统均能够通过该业务处理模型实现任一业务,通用性较高,避免了定制化业务系统仅限于特定业务场景使用导致的通用性较低的问题。
需要说明的是:上述实施例提供的业务处理装置在进行业务处理时,仅以上述各功能模块的划分进行举例说明,实际应用中,可以根据需要而将上述功能分配由不同的功能模块完成,即将装置的内部结构划分成不同的功能模块,以完成以上描述的全部或者部分功能。另外,上述实施例提供的业务处理装置与业务处理方法实施例属于同一构思,其具体实现过程详见方法实施例,这里不再赘述。
图5是本申请实施例提供的一种业务处理装置500的结构示意图,该业务处理装置500可因配置或性能不同而产生比较大的差异,可以包括一个或一个以上处理器(centralprocessing units,CPU)501和一个或一个以上的存储器502,其中,所述存储器502中存储有至少一条指令,所述至少一条指令由所述处理器501加载并执行以实现上述各个方法实施例提供的业务处理方法。当然,该业务处理装置500还可以具有有线或无线网络接口、键盘以及输入输出接口等部件,以便进行输入输出,该业务处理装置500还可以包括其他用于实现设备功能的部件,在此不做赘述。该业务处理装置500可以为计算机设备,该计算机设备可以为终端或服务器。
本领域普通技术人员可以理解实现上述实施例的全部或部分步骤可以通过硬件来完成,也可以通过程序来指令相关的硬件完成,所述的程序可以存储于一种计算机可读存储介质中,上述提到的存储介质可以是只读存储器,磁盘或光盘等。
以上所述仅为本申请的较佳实施例,并不用以限制本申请,凡在本申请的精神和原则之内,所作的任何修改、等同替换、改进等,均应包含在本申请的保护范围之内。
Claims (10)
1.一种业务处理方法,其特征在于,所述方法包括:
从业务处理模型的配置信息中确定目标业务流程的业务流程方法,所述业务处理模型用于配置任一业务流程的业务流程方法、回滚方法和异常处理方式,所述异常处理方式包括回滚或补偿;
基于所述目标业务流程的业务流程方法,运行所述目标业务流程;
当检测到所述目标业务流程运行异常时,从所述业务处理模型的配置信息中确定所述目标业务流程的异常处理方式,以及与所述目标业务流程的异常处理方式对应的异常处理方法,所述异常处理方法为所述目标业务流程的业务流程方法或回滚方法;
调用所述异常处理方法,基于所述目标业务流程的运行信息,执行调用的异常处理方法。
2.根据权利要求1所述的方法,其特征在于,所述业务处理模型包括业务流程模型、异常配置项和配置入口,所述配置入口用于通过在所述业务流程模型中注解业务流程方法参数和回滚方法参数,配置任一业务流程的业务流程方法和回滚方法,且所述配置入口用于在所述异常配置项中配置任一业务流程的异常处理方式。
3.根据权利要求3所述的方法,其特征在于,所述业务处理模型还包括业务流程步骤模型,所述配置入口用于通过在所述业务流程步骤模型中注解业务流程步骤方法参数和回滚方法参数,配置任一业务流程包括的各个业务流程步骤的业务流程步骤方法和回滚方法。
4.根据权利要求1所述的方法,其特征在于,所述从所述业务处理模型的配置信息中确定与所述目标业务流程的异常处理方式对应的异常处理方法,包括:
若所述目标业务流程的异常处理方式为回滚,则从所述业务处理模型的配置信息中确定所述目标业务流程的回滚方法,将所述目标业务流程的回滚方法,作为与所述目标业务流程的异常处理方式对应的异常处理方法;
所述调用所述异常处理方法,基于所述目标业务流程的运行信息,执行调用的异常处理方法,包括:
从所述目标业务流程的运行信息中,确定所述目标业务流程的流程参数;
调用所述目标业务流程的回滚方法,将所述流程参数作为所述目标业务流程的回滚方法的入参,执行所述目标业务流程的回滚方法。
5.根据权利要求4所述的方法,其特征在于,所述业务处理模型还用于配置任一业务流程包括的各个业务流程步骤的回滚方法,所述方法还包括:
从所述目标业务流程包括的多个业务流程步骤中,确定运行异常的业务流程步骤,以及步骤顺序位于运行异常的业务流程步骤之前的目标业务流程步骤;
从所述业务处理模型的配置信息中,确定所述目标业务流程步骤的回滚方法;
从所述目标业务流程的运行信息中,确定所述目标业务流程步骤的步骤参数;
调用所述目标业务流程步骤的回滚方法,将所述目标业务流程步骤的步骤参数作为所述目标业务流程步骤的回滚方法的入参,执行调用的所述目标业务流程步骤的回滚方法。
6.根据权利要求1所述的方法,其特征在于,所述从所述业务处理模型的配置信息中确定与所述目标业务流程的异常处理方式对应的异常处理方法,包括:
若所述目标业务流程的异常处理方式为补偿,则从所述业务处理模型的配置信息中确定所述目标业务流程的业务流程方法,将所述目标业务流程的业务流程方法,作为与所述目标业务流程的异常处理方式对应的异常处理方法;
所述调用所述异常处理方法,基于所述目标业务流程的运行信息,执行调用的异常处理方法,包括:
从所述目标业务流程的运行信息中,确定所述目标业务流程的流程参数;
调用所述目标业务流程的业务流程方法,将所述流程参数作为所述目标业务流程的业务流程方法的入参,执行调用的所述目标业务流程的业务流程方法。
7.根据权利要求1-6任一所述的方法,其特征在于,所述基于所述目标业务流程的运行信息,执行调用的异常处理方法之后,还包括:
若所述异常处理方法执行失败且所述异常处理方法的已执行次数小于次数阈值,则重复执行所述异常处理方法;
若所述异常处理方法执行失败且所述异常处理方法的已执行次数等于所述次数阈值,则进行异常提醒。
8.一种业务处理装置,其特征在于,所述装置包括:
第一确定模块,用于从业务处理模型的配置信息中确定目标业务流程的业务流程方法,所述业务处理模型用于配置任一业务流程的业务流程方法、回滚方法和异常处理方式,所述异常处理方式包括回滚或补偿;
运行模块,用于基于所述目标业务流程的业务流程方法,运行所述目标业务流程;
第二确定模块,用于当检测到所述目标业务流程运行异常时,从所述业务处理模型的配置信息中确定所述目标业务流程的异常处理方式,以及与所述目标业务流程的异常处理方式对应的异常处理方法,所述异常处理方法为所述目标业务流程的业务流程方法或回滚方法;
执行模块,用于调用所述异常处理方法,基于所述目标业务流程的运行信息,执行调用的异常处理方法。
9.一种业务处理装置,其特征在于,所述装置包括:
一个或多个处理器;
用于存储所述一个或多个处理器可执行指令的一个或多个存储器;
其中,所述一个或多个处理器被配置为执行权利要求1-7任一项所述的业务处理方法。
10.一种非临时性计算机可读存储介质,其特征在于,所述存储介质上存储有指令,所述指令被处理器执行时实现权利要求1-7任一项所述的业务处理方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910872246.0A CN110599305A (zh) | 2019-09-16 | 2019-09-16 | 业务处理方法、装置及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910872246.0A CN110599305A (zh) | 2019-09-16 | 2019-09-16 | 业务处理方法、装置及存储介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN110599305A true CN110599305A (zh) | 2019-12-20 |
Family
ID=68859822
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201910872246.0A Pending CN110599305A (zh) | 2019-09-16 | 2019-09-16 | 业务处理方法、装置及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN110599305A (zh) |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN111865686A (zh) * | 2020-07-20 | 2020-10-30 | 北京百度网讯科技有限公司 | 云产品扩容方法、装置、设备以及存储介质 |
CN112948434A (zh) * | 2021-02-25 | 2021-06-11 | 平安壹钱包电子商务有限公司 | 基于业务事件的业务处理方法、装置、计算机设备及存储介质 |
CN113570334A (zh) * | 2021-07-27 | 2021-10-29 | 浪潮通用软件有限公司 | 一种基于单据流程的异构系统交互方法、设备及介质 |
CN114302438A (zh) * | 2021-12-29 | 2022-04-08 | 中国电信股份有限公司 | 网元的异常处理方法、装置、设备以及存储介质 |
-
2019
- 2019-09-16 CN CN201910872246.0A patent/CN110599305A/zh active Pending
Cited By (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN111865686A (zh) * | 2020-07-20 | 2020-10-30 | 北京百度网讯科技有限公司 | 云产品扩容方法、装置、设备以及存储介质 |
CN112948434A (zh) * | 2021-02-25 | 2021-06-11 | 平安壹钱包电子商务有限公司 | 基于业务事件的业务处理方法、装置、计算机设备及存储介质 |
CN112948434B (zh) * | 2021-02-25 | 2024-04-09 | 平安壹钱包电子商务有限公司 | 基于业务事件的业务处理方法、装置、计算机设备及存储介质 |
CN113570334A (zh) * | 2021-07-27 | 2021-10-29 | 浪潮通用软件有限公司 | 一种基于单据流程的异构系统交互方法、设备及介质 |
CN113570334B (zh) * | 2021-07-27 | 2023-07-18 | 浪潮通用软件有限公司 | 一种基于单据流程的异构系统交互方法、设备及介质 |
CN114302438A (zh) * | 2021-12-29 | 2022-04-08 | 中国电信股份有限公司 | 网元的异常处理方法、装置、设备以及存储介质 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN110599305A (zh) | 业务处理方法、装置及存储介质 | |
CN111290866B (zh) | 业务处理方法及装置 | |
CN109598407B (zh) | 一种业务流程的执行方法及装置 | |
CN107016029B (zh) | 一种业务数据的处理方法、装置及系统 | |
CN112817995B (zh) | 数据处理方法和装置、电子设备及存储介质 | |
CN112035344A (zh) | 多场景测试方法、装置、设备和计算机可读存储介质 | |
CN113282436A (zh) | 事件处理方法、装置、设备以及存储介质 | |
US11074112B2 (en) | Maintaining the responsiveness of a user interface while performing a synchronous operation | |
CN112181378A (zh) | 业务流程的实现方法及装置 | |
WO2020253045A1 (zh) | 配置化的数据转发异常补处理方法、装置及可读存储介质 | |
CN115964153A (zh) | 一种异步任务处理方法、装置、设备以及存储介质 | |
CN106603125B (zh) | 一种与蓝牙设备进行数据交互的方法及装置 | |
CN111294377B (zh) | 一种依赖关系的网络请求发送方法、终端装置及存储介质 | |
US20220035666A1 (en) | Method and apparatus for data processing, server and storage medium | |
CN111159298A (zh) | 业务请求处理方法、装置、电子设备及存储介质 | |
CN112445860A (zh) | 一种处理分布式事务的方法和装置 | |
CN113986941A (zh) | 事务批量处理方法及装置 | |
CN111061576B (zh) | 一种实体对象的创建方法及系统 | |
CN110765144B (zh) | 分布式异构数据库数据处理方法及装置 | |
CN114064343A (zh) | 一种区块链的异常处置方法及装置 | |
CN113032118A (zh) | 用于计算机应用程序的异步操作处理方法和相应的系统 | |
CN111538491A (zh) | 数据事件处理方法、装置、设备和存储介质 | |
CN217825010U (zh) | 通信测试系统 | |
CN114900531B (zh) | 数据同步方法、装置和系统 | |
CN111966427B (zh) | 一种Android native调用Java API的实现方法 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination |