CN112905270B - 工作流实现方法、装置、平台、电子设备以及存储介质 - Google Patents
工作流实现方法、装置、平台、电子设备以及存储介质 Download PDFInfo
- Publication number
- CN112905270B CN112905270B CN202110192174.2A CN202110192174A CN112905270B CN 112905270 B CN112905270 B CN 112905270B CN 202110192174 A CN202110192174 A CN 202110192174A CN 112905270 B CN112905270 B CN 112905270B
- Authority
- CN
- China
- Prior art keywords
- target
- workflow
- instruction
- flow
- language
- 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.)
- Active
Links
- 238000000034 method Methods 0.000 title claims abstract description 121
- 238000006243 chemical reaction Methods 0.000 claims abstract description 74
- 238000012545 processing Methods 0.000 claims abstract description 63
- 238000004590 computer program Methods 0.000 claims description 14
- 230000008569 process Effects 0.000 description 51
- 238000007726 management method Methods 0.000 description 40
- 238000010586 diagram Methods 0.000 description 17
- 238000004891 communication Methods 0.000 description 8
- 238000013461 design Methods 0.000 description 6
- 230000000694 effects Effects 0.000 description 5
- 230000003993 interaction Effects 0.000 description 5
- 238000005516 engineering process Methods 0.000 description 4
- 230000006870 function Effects 0.000 description 4
- 230000000977 initiatory effect Effects 0.000 description 4
- 238000004458 analytical method Methods 0.000 description 3
- 238000012986 modification Methods 0.000 description 3
- 230000004048 modification Effects 0.000 description 3
- 230000003287 optical effect Effects 0.000 description 3
- 230000000007 visual effect Effects 0.000 description 3
- 238000013523 data management Methods 0.000 description 2
- 238000011112 process operation Methods 0.000 description 2
- 230000001960 triggered effect Effects 0.000 description 2
- 241001409866 Actitis Species 0.000 description 1
- 238000003491 array Methods 0.000 description 1
- 238000013473 artificial intelligence Methods 0.000 description 1
- 230000001413 cellular effect Effects 0.000 description 1
- 238000010276 construction Methods 0.000 description 1
- 230000007547 defect Effects 0.000 description 1
- 238000011161 development Methods 0.000 description 1
- 230000010354 integration Effects 0.000 description 1
- 239000004973 liquid crystal related substance Substances 0.000 description 1
- 238000010801 machine learning Methods 0.000 description 1
- 238000012544 monitoring process Methods 0.000 description 1
- 239000013307 optical fiber Substances 0.000 description 1
- 238000004886 process control Methods 0.000 description 1
- 239000004065 semiconductor Substances 0.000 description 1
- 230000001953 sensory effect Effects 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/44—Arrangements for executing specific programs
- G06F9/448—Execution paradigms, e.g. implementations of programming paradigms
- G06F9/4482—Procedural
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Management, Administration, Business Operations System, And Electronic Commerce (AREA)
Abstract
本公开公开了工作流实现方法、装置、平台、电子设备以及存储介质,涉及计算机技术领域,尤其涉及信息化管理技术领域。具体实现方案为:接收流程启动指令,其中,所述流程启动指令包括:第一指令内容、模板标识以及目标标识;按照与所述目标标识对应的目标工作流引擎的语言,对所述第一指令内容进行语言转换,以得到第一目标指令内容;调用所述目标工作流引擎按照所述第一目标指令内容对所述模板标识对应的目标流程模板进行实例化处理以及运行处理,以实现所述工作流。由此,提高了工作流的实现效率。
Description
技术领域
本公开涉及计算机技术领域,特别涉及信息化管理技术领域,尤其涉及工作流实现方法、装置、平台、电子设备以及存储介质。
背景技术
随着信息化技术的发展,工作流的作用越来越不可或缺,各式各样的工作流引擎设计方案也层出不穷。
相关技术中,基于UML Activity Diagram(Unified Modeling LanguageActivityDiagram,统一建模语言活动图)的工作引擎Activiti,由于其功能强大的特点而被广泛使用,然而这种工作引擎的流程设计过重,比如引入了流程存储、流程任务和管理、流程控制和历史数据管理等概念,且引入套件过多,例如引入了可视化设计,从而导致用户很难快速了解和使用这种工作引擎,进而导致工作流的实现效率差。
发明内容
本公开提供了一种工作流实现方法、装置、平台、电子设备、存储介质以及计算机程序产品。
根据本公开的一方面,提供了一种工作流实现方法,包括:接收流程启动指令,其中,所述流程启动指令包括:第一指令内容、模板标识以及目标标识;按照与所述目标标识对应的目标工作流引擎的语言,对所述第一指令内容进行语言转换,以得到第一目标指令内容;调用所述目标工作流引擎按照所述第一目标指令内容对所述模板标识对应的目标流程模板进行实例化处理以及运行处理,以实现所述工作流。
根据本公开的另一方面,提供了一种工作流实现装置,包括:第一接收模块,用于接收流程启动指令,其中,所述流程启动指令包括:第一指令内容、模板标识以及目标标识;第一转换模块,用于按照与所述目标标识对应的目标工作流引擎的语言,对所述第一指令内容进行语言转换,以得到第一目标指令内容;第一处理模块,用于调用所述目标工作流引擎按照所述第一目标指令内容对所述模板标识对应的目标流程模板进行实例化处理以及运行处理,以实现所述工作流。
根据本公开的另一方面,提供了一种工作流实现平台,包括:依次连接的接口层、适配器层、工作流引擎层和存储层;其中,所述接口层,用于接收工作流相关的指令;所述适配器层,包括:每个工作流引擎对应的适配器,用于对所述指令进行语言转换,得到工作流引擎能够识别的指令;所述工作流引擎层,包括:多个工作流引擎,用于执行对应的指令;所述存储层,用于存储所述接口层、所述适配器层和所述工作流引擎层接收到的数据以及处理得到的中间数据。
根据本公开的另一方面,提供了一种电子设备,包括:至少一个处理器;以及与所述至少一个处理器通信连接的存储器;其中,所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行如上所述的工作流实现方法。
根据本公开的另一方面,提供了一种存储有计算机指令的非瞬时计算机可读存储介质,所述计算机指令用于使所述计算机执行如上所述的工作流实现方法。
根据本公开的另一方面,提供了一种计算机程序产品,包括计算机程序,所述计算机程序在被处理器执行时实现根据如上所述的工作流实现方法。
应当理解,本部分所描述的内容并非旨在标识本公开的实施例的关键或重要特征,也不用于限制本公开的范围。本公开的其它特征将通过以下的说明书而变得容易理解。
附图说明
附图用于更好地理解本方案,不构成对本公开的限定。其中:
图1是根据本公开第一实施例的工作流实现平台的框架示意图;
图2是根据本公开第二实施例的工作流实现方法的流程示意图;
图3是根据本公开第三实施例的工作流实现方法的流程示意图;
图4是根据本公开第四实施例的工作流实现方法的流程示意图;
图5是根据本公开第五实施例的工作流实现方法的流程示意图;
图6是根据本公开第六实施例的工作流实现装置的结构示意图;
图7是根据本公开第七实施例的工作流实现装置的结构示意图;
图8是用来实现本公开实施例的工作流实现方法的电子设备的框图。
具体实施方式
以下结合附图对本公开的示范性实施例做出说明,其中包括本公开实施例的各种细节以助于理解,应当将它们认为仅仅是示范性的。因此,本领域普通技术人员应当认识到,可以对这里描述的实施例做出各种改变和修改,而不会背离本公开的范围和精神。同样,为了清楚和简明,以下的描述中省略了对公知功能和结构的描述。
需要说明的是,本申请中的字符“/”表示前后关联对象是一种“或”的关系,比如“A/B”,表示A或B。
可以理解的是,相关技术中,基于UML Activity Diagram的工作引擎Activiti,由于其功能强大的特点而被广泛使用,然而这种工作引擎的流程设计过重,比如引入了流程存储、流程任务和管理、流程控制和历史数据管理等概念,且引入套件过多,例如引入了可视化设计,从而导致用户很难快速了解和使用这种工作引擎,进而导致工作流的实现效率差。
本公开为了提高工作流的实现效率,提出一种工作流实现方法,该工作流实现方法,首先接收流程启动指令,其中,流程启动指令包括:第一指令内容、模板标识以及目标标识,再按照与目标标识对应的目标工作流引擎的语言,对第一指令内容进行语言转换,以得到第一目标指令内容,再调用目标工作流引擎按照第一目标指令内容对模板标识对应的目标流程模板进行实例化处理以及运行处理,以实现工作流。由此,提高了工作流的实现效率。
下面参考附图描述本公开实施例的工作流实现方法、装置、平台、电子设备、非瞬时计算机可读存储介质以及计算机程序产品。
首先结合图1,对本公开提供的工作流实现平台进行详细描述。
图1是根据本公开第一实施例的工作流实现平台的框架示意图。
如图1所示,本申请提供的工作流实现平台10,包括依次连接的接口层110、适配器层120、工作流引擎层130和存储层140。
其中,接口层110,用于接收工作流相关的指令;
适配器层120,包括:每个工作流引擎对应的适配器,用于对指令进行语言转换,得到工作流引擎能够识别的指令;
工作流引擎层130,包括:多个工作流引擎,用于执行对应的指令;
存储层140,用于存储接口层110、适配器层120和工作流引擎层130接收到的数据以及处理得到的中间数据。
本申请实施例中,可以根据应用场景,自定义工作流程的各个阶段(或称为节点),比如pass(通过)阶段、wait(等待)阶段、task(任务)阶段、choice(选择)阶段、approve(批准)阶段、parallel(并行)阶段。
其中,在流程执行到pass阶段时,会继续跳转到下一阶段;在流程执行到wait阶段时,流程会等待某个触发条件后再继续执行,比如等待预设时间段后自动继续执行或者用户手动触发后再执行;在流程执行到task阶段时,会产生一个任务,在将该任务执行完成后,会跳转到下一个确定的任务;在流程执行到choice阶段时,会根据上一阶段输出的参数等数据选择跳转到其它多个阶段中的哪一个阶段;approve阶段相当于task阶段与choice阶段的整合,在流程执行到approve阶段时,可以执行任务,也可以在执行任务完成后根据阶段输出的参数等数据选择跳转到其它多个阶段中的哪一个阶段;在流程执行到parallel阶段时,可以选择并行执行多个子任务或者子流程。
并且,本申请实施例中,在接口层110中设置有多种接口,例如如图1所示,可以设置流程部署接口111、流程启动接口112、流程停止接口113、阶段触发接口114、任务完成接口115以及模板/实例查询接口116。
其中,流程部署接口111,可以接收携带用户编写的工作流的描述文件的流程部署指令,从而使得工作流实现平台可以通过执行该指令,对工作流的描述文件进行部署处理,得到目标流程模板。流程启动接口112,可以接收携带目标流程模板的模板标识的流程启动指令,从而使得工作流实现平台可以通过执行该指令,将模板标识对应的目标工作流程模板转化成一个流程实例,其中,每个流程实例表示一个正在进行或者已经结束的工作流。流程停止接口113,可以接收携带目标流程实例标识的流程结束指令,从而使得工作流实现平台可以通过执行该指令,结束目标流程实例。阶段触发接口114,可以接收携带目标流程实例标识和节点关键字的阶段触发指令,从而使得工作流实现平台可以通过执行该指令,在流程实例处于阶段关键字对应的阶段时,并且此阶段的类型为wait时,结束该阶段。任务完成接口115,可以接收携带目标流程实例的实例标识、目标任务标识、任务执行的参数的任务完成指令,从而使得工作流实现平台可以通过执行该指令,在流程实例当前执行某个处于task阶段或approve阶段的任务,并且该任务的任务标识为目标任务标识时,结束这个阶段。模板/实例查询接口116,可以接收携带目标流程模板的模板标识的流程模板查询指令或携带目标流程实例的实例标识的流程实例查询指令,从而使得工作流实现平台可以通过执行流程模板查询指令,查询模板标识对应的目标流程模板,通过执行流程实例查询指令,查询目标流程实例执行过程中的任务信息,比如流程处于正在执行的状态还是已结束的状态,以及当前进行中的任务列表。
另外,在工作流实现平台中设置有工作流引擎层130,工作流引擎层130中包括多个工作流引擎,在实际应用中,接口层110接收的工作流相关的指令中,可以携带需要用来执行该指令的目标工作流引擎的目标标识,从而可以调用目标工作流引擎执行接口层接收的与工作流相关的指令。
其中,工作流引擎层130中包括的多个工作流引擎,可以为任意模式的工作流引擎,比如工作流引擎层130中可以包括基于UML Activity Diagram的工作流引擎,例如JBPM(Java Business Process Management,Java业务流程管理)系统或图1中的Activiti 131)以及基于Finite State Machine(FSM有限状态机)的工作流引擎,例如图1中的OSWorkflow132,还可以包括自主研发的工作流引擎133,本申请对工作流引擎层中包括的工作流引擎的模式及数量等不作限制。
本申请实施例中,接口层110接收的工作流相关的指令以及指令中携带的各种数据的定义语言,比如流程部署指令以及流程部署指令中携带的工作流的描述文件等的定义语言,流程启动指令以及流程启动指令中携带的指令内容,可以根据需要设置为预设语言。为了使用户利用工作流实现平台实现工作流时,能够快速了解和使用工作流实现平台,可以设置预设语言为简洁、容易理解,且方便用json(JavaScript Object Notation,一种简单的数据格式)的形式表达的语言,比如ASL(Amazon State Language,亚马逊状态机语言)。相应的,在本申请实施例中,为了使得工作流实现平台的工作流引擎层130中的各个工作流引擎能够识别接口层110接收的工作流相关的指令以及指令中的数据,可以在工作流实现平台中设置适配器层120,适配器层120分别与接口层110以及工作流引擎层130连接,从而能够对接口层110中接收的指令以及指令中的各种数据进行语言转换,得到工作流引擎层130能够识别的指令以及数据,进而将工作流引擎层130能够识别的指令以及数据发送至工作流引擎层130,以便工作流引擎层130能够执行对应的指令。
其中,本申请实施例中,适配器层120中包括与工作流引擎层130中的每个工作流引擎分别对应的适配器,从而通过各个适配器,可以将接口层110接收的指令以及指令中的各种数据转换为对应的工作流引擎能够识别的指令以及数据。
另外,为了进一步使用户快速了解和使用工作流实现平台,本申请实施例中在利用ASL作为指令及数据的定义语言时,还对ASL语言中定义的指令进行了简化。例如,整合了task和choice阶段,新定义了一个approve阶段;增加了流程监听器和阶段监听器,使得工作流实现平台可以根据接口层接收到的用户指令,对流程实例的执行状态进行监听,并将监听结果通知给用户;自定义了task、choice以及parallel阶段的内容以及含义。
下面对本申请实施例中利用ASL作为指令及数据的定义语言时,定义的指令进行简单介绍。
其中,定义了流程的描述信息,有以下几个属性:name,为流程的名称;comment,为流程的描述;listeners,为流程监听器列表;stages,为流程阶段列表;start,为流程开始阶段的key(关键)值。定义了流程监听器,有如下几个属性:event,为监听的事件,目前只有start和end,表示流程开始和结束;callback,为当监听到对应的事件时回调的地址,请求方式为POST方式;其中,同一个event和callback只会通知一次。定义了流程阶段,有如下几个属性:key,为阶段的key值,不能重复;type,为类型,目前支持pass/wait/task/choice/approve/parallel类型;name,为阶段名;comment,为阶段的描述;listeners,为阶段监听器列表,仅在task/approve类型阶段才生效;end,为阶段执行完是否结束,如果为true(真值),则执行完此阶段后流程结束,choice/approve类型阶段不生效;next,为下个阶段的key值,在end为true时不生效,choice/approve类型阶段不生效;seconds,为等待触发的秒数,wait阶段才生效,如果为0,则会一直等待直到有这个阶段的触发信号到来;choices,为选择项列表,choice/approve类型阶段才生效;branches,为子流程列表,parallel类型阶段才生效,列表每一项都是一个流程(flow),必须要所有子流程结束后此阶段才会结束(触发end或next)。定义了阶段监听器,有如下几个属性:event,为监听的事件,目前只有start和end,表示阶段开始和结束;callback,为当监听到对应的事件时回调的地址,请求方式为POST方式;其中,同一个event和callback只会通知一次。定义了阶段选择项,有如下几个属性:condition,为判断条件,值为EL(Expression Language,表达语言)表达式,选择项列表中必须有且只有一个表达式成立;end,为condition(条件)成立后是否结束,如果为true,则执行完流程结束;next,为condition(条件)成立后下个阶段的key值,end为true不生效。
在示例性实施例中,存储器140,可以包括关系型数据库和非关系型数据库,用于存储接口层、适配器层和工作流引擎层接收到的数据以及处理得到的中间数据。比如,接口层接收的流程部署指令以及指令中包括的工作流的描述文件、目标工作流引擎的目标标识,接口层接收的流程启动指令以及指令中包括的指令内容、模板标识以及目标工作流引擎的目标标识,适配器层120对接口层接收的工作流相关的指令进行语言转换后的目标指令以及目标描述文件,以及工作流引擎层调用目标工作流引擎对目标描述文件进行部署处理后的目标流程模板等。
本申请实施例提供的工作流实现平台,由于设置了适配器层120,适配器层120可以对接口接收的工作流相关的指令以及指令中的各种数据进行语言转换,得到工作流引擎层能够识别的指令以及数据,进而利用工作流引擎层执行接口接收的指令,从而接口接收的工作流相关的指令以及指令中的各种数据,可以通过简洁、容易理解,且方便用json的形式表达的预设语言进行定义,在用户利用工作流实现平台实现工作流时,能够更快速的学习工作流实现平台的定义语言,更方便的生成指令以及指令中的数据比如工作流的描述文件,从而提高了工作流的实现效率。并且,由于在工作流引擎层中设置了多个工作流引擎,能够根据实际业务场景调用合适的工作流引擎来实现工作流,从而进一步提高了工作流的实现效率。
基于上述工作流实现平台,本申请还提出一种工作流实现方法。下面结合图2,对本公开实施例提供的工作流实现方法进行说明。其中,需要说明的是,本实施例提供的工作流实现方法,执行主体为工作流实现装置,该工作流实现装置可以嵌入工作流实现平台中,以提高工作流的实现效率。
其中,工作流实现平台可以被配置在电子设备中,电子设备可以是任意能够进行数据处理的计算设备,例如笔记本电脑、智能手机、可穿戴设备等计算设备或者服务器等,本公开对此不作限制。
图2是根据本公开第二实施例的工作流实现方法的流程示意图。
如图2所示,工作流实现方法,可以包括以下步骤:
步骤201,接收流程启动指令,其中,流程启动指令包括:第一指令内容、模板标识以及目标标识。
其中,第一指令内容,用于表征对应指令为何种指令,比如流程启动指令中的第一指令内容表征该流程启动指令为用于进行流程启动的指令,流程部署指令中的第二指令内容表征该流程部署指令为用于进行流程部署的指令,流程查询指令中的指令内容表征该流程查询指令为用于进行流程查询的指令。其中,第一指令内容的定义语言可以根据需要设置。
模板标识,用于唯一标识目标流程模板,比如,可以为目标流程模板的预设标号,目标流程模板的名称,等等。
在示例性实施例中,在工作流实现平台中可以预先部署多个流程模板,并将各流程模板的标识展示给用户,从而使用户可以根据需要,从多个流程模板中选择所需的目标流程模板,并将目标流程模板的模板标识携带在流程启动指令中。
目标标识,用于唯一标识流程启动指令对应的目标工作流引擎,比如,可以为目标工作流引擎的预设标号,目标工作流引擎的名称,等等。
在示例性实施例中,可以设置工作流实现平台的工作流引擎层中包括多个工作流引擎,并且可以预先设置各个工作流引擎分别对应的标识,从而在用户需要利用工作流引擎层中的某个工作流引擎实现某个流程模板对应的工作流时,可以将该工作流引擎作为目标工作流引擎,将该流程模板作为目标流程模板,并在流程启动指令中包括该目标工作流引擎对应的目标标识、目标流程模板对应的模板标识以及指示该指令为流程启动指令的第一指令内容,以在工作流实现平台接收到流程启动指令后,根据流程启动指令中包括的目标标识,选择目标工作流引擎将模板标识对应的目标流程模板转化为流程实例并运行流程实例,实现工作流。
其中,流程启动指令,可以是通过工作流实现平台的接口层中的流程启动接口接收的。
步骤202,按照与目标标识对应的目标工作流引擎的语言,对第一指令内容进行语言转换,以得到第一目标指令内容。
其中,第一目标指令内容,为目标标识对应的目标工作流引擎能够识别的、与目标标识对应的目标工作流引擎的语言对应的指令内容。
在示例性实施例中,工作流实现平台中设置有适配器层,且适配器层中包括与各工作流引擎分别对应的适配器,从而在接收到流程启动指令后,可以通过目标标识对应的目标工作流引擎对应的适配器,对流程启动指令中的第一指令内容进行语言转换,以得到第一目标指令内容。
步骤203,调用目标工作流引擎按照第一目标指令内容对模板标识对应的目标流程模板进行实例化处理以及运行处理,以实现工作流。
在示例性实施例中,可以根据目标标识,调用工作流引擎层中与目标标识对应的目标工作流引擎,从而利用该目标工作流引擎按照第一目标指令内容对模板标识对应的目标流程模板进行实例化处理以及运行处理,以实现工作流。
在示例性实施例中,调用目标工作流引擎对目标流程模板进行实例化处理以及运行处理的过程可以为:调用目标工作流引擎对目标流程模板进行实例化处理,以生成与目标流程模板对应的目标流程实例;调用目标工作流引擎运行目标流程实例,以实现工作流。具体的实例化处理过程及运行目标流程实例的过程,可以参考相关技术,本申请对此不作赘述。
本申请实施例中,接收到包括第一指令内容、模板标识以及目标标识的流程启动指令后,由于可以按照与目标标识对应的目标工作流引擎的语言,对流程启动指令中的第一指令内容进行语言转换,得到目标工作流引擎能够识别的第一目标指令内容,进而调用目标工作流引擎按照第一目标指令内容对模板标识对应的目标流程模板进行实例化处理以及运行处理,以实现工作流,从而用户在生成指令内容等数据时,可以通过简洁、容易理解,且方便用json的形式表达的预设语言进行定义,在用户利用工作流实现平台实现工作流时,能够更快速的学习工作流实现平台的定义语言,更方便的生成指令内容等数据,从而提高了工作流的实现效率。并且,由于可以根据实际业务场景,调用合适的工作流引擎来实现工作流,从而进一步提高了工作流的实现效率。
本公开实施例提供的工作流实现方法,首先接收流程启动指令,其中,流程启动指令包括:第一指令内容、模板标识以及目标标识,再按照与目标标识对应的目标工作流引擎的语言,对第一指令内容进行语言转换,以得到第一目标指令内容,再调用目标工作流引擎按照第一目标指令内容对模板标识对应的目标流程模板进行实例化处理以及运行处理,以实现工作流。由此,提高了工作流的实现效率。
通过上述分析可知,在本公开实施例中,可以按照与目标标识对应的目标工作流引擎的语言,对流程启动指令中的第一指令内容进行语言转换,得到第一目标指令内容,下面结合图3,对本公开提供的工作流实现方法中,对流程启动指令中的第一指令内容进行语言转换的过程进一步说明。
图3是根据本公开第三实施例的工作流实现方法的流程示意图。如图3所示,工作流实现方法,可以包括以下步骤:
步骤301,接收流程启动指令,其中,流程启动指令包括:第一指令内容、模板标识以及目标标识。
其中,上述步骤301的具体实现过程及原理,可以参考上述实施例的描述,此处不再赘述。
在示例性实施例中,可以在电子设备的人机交互界面上显示工作流的相关指令对应的原始描述语言,从而在用户需要实现工作流时,可以结合显示的原始描述语言进行相关指令的编写。
需要说明的是,显示原始描述语言时,可以显示一种原始描述语言,从而使用户可以结合该原始描述语言进行相关指令的编写,或者,也可以显示多种原始描述语言,从而使用户可以结合多种原始描述语言中的任一种原始描述语言进行相关指令的编写。
在示例性实施例中,还可以在人机交互界面上显示各个工作流引擎的标识,以便用户能够从显示的各个标识中选择需要利用的目标工作流引擎对应的目标标识。
步骤302,获取第一指令内容的原始描述语言,以及与目标标识对应的目标工作流引擎的语言。
在示例性实施例中,在显示一种原始描述语言时,可以直接将显示的原始描述语言确定为第一指令内容的原始描述语言,在显示多种原始描述语言时,可以对第一指令内容进行解析,以确定第一指令内容的原始描述语言。
在示例性实施例中,在接收到流程启动指令后,可以根据流程启动指令中包括的目标标识,确定目标工作流引擎,进而获取目标标识对应的目标工作流引擎的语言。
步骤303,确定原始描述语言与目标工作流引擎的语言之间的转换策略。
步骤304,按照转换策略,对第一指令内容进行语言转换,以得到第一目标指令内容。
在示例性实施例中,在确定第一指令内容的原始描述语言以及目标工作流引擎的语言之后,即可确定原始描述语言与目标工作流引擎的语言之间的转换策略,进而按照转换策略,对第一指令内容进行语言转换,以得到第一目标指令内容。
步骤305,调用目标工作流引擎按照第一目标指令内容对模板标识对应的目标流程模板进行实例化处理以及运行处理,以实现工作流。
其中,步骤305的具体实现过程及原理,可以参考上述实施例的描述,此处不再赘述。
本公开实施例提供的工作流实现方法,在接收包括第一指令内容、模板标识以及目标标识的流程启动指令后,先获取第一指令内容的原始描述语言,以及与目标标识对应的目标工作流引擎的语言,再确定原始描述语言与目标工作流引擎的语言之间的转换策略,再按照转换策略,对第一指令内容进行语言转换,以得到第一目标指令内容,进而调用目标工作流引擎按照第一目标指令内容对模板标识对应的目标流程模板进行实例化处理以及运行处理,以实现工作流。由此,实现了将对应语言为原始描述语言的第一指令内容,转换为目标工作流引擎能够识别的第一目标指令内容,进而能够利用目标工作流引擎执行流程启动指令,以实现工作流,方便了用户生成指令内容,提高了工作流的实现效率。
通过上述分析可知,在本公开实施例中,可以调用目标工作流引擎按照第一目标指令内容对模板标识对应的目标流程模板进行实例化处理以及运行处理,以实现工作流,在一种可能的实现形式中,工作流实现平台中可能未提前部署目标流程模板,那么,在执行流程启动指令之前,还需要先进行流程部署,以得到目标流程模板。下面针对上述情况,结合图4,对本公开提供的工作流实现方法进行进一步说明。
图4是根据本公开第四实施例的工作流实现方法的流程示意图。如图4所示,工作流实现方法,可以包括以下步骤:
步骤401,接收流程部署指令,其中,流程部署指令包括:第二指令内容、工作流的描述文件以及目标标识。
其中,第二指令内容,用于表征对应指令为用于进行流程部署的指令。
工作流的描述文件,为描述工作流中的各个阶段、各个阶段之间的流转关系等的文件。其中,工作流的描述文件的定义语言可以根据需要设置。
目标标识,用于唯一标识流程部署指令对应的目标工作流引擎,比如,可以为目标工作流引擎的预设标号,目标工作流引擎的名称,等等。
在示例性实施例中,可以设置工作流实现平台的工作流引擎层中包括多个工作流引擎,并且可以预先设置各个工作流引擎分别对应的标识,从而在用户需要利用工作流引擎层中的某个工作流引擎进行流程部署时,可以将该工作流引擎作为目标工作流引擎,并在流程部署指令中包括该目标工作流引擎对应的目标标识、工作流的描述文件以及第二指令内容,以在工作流实现平台接收到流程部署指令后,根据流程部署指令中包括的目标标识,选择目标工作流引擎按照第二指令内容及工作流的描述文件进行流程部署。
其中,流程部署指令,可以是通过工作流实现平台的接口层中的流程部署接口接收的。
在示例性实施例中,可以在电子设备的人机交互界面上显示工作流的相关指令的原始描述语言以及工作流引擎层中包括的各个工作流引擎的标识,从而在用户需要进行流程部署时,可以结合显示的原始描述语言进行描述文件的编写,以提供原始描述语言对应的描述文件,并且能够从显示的各个标识中选择需要利用的目标工作流引擎对应的目标标识。
即,在步骤401之前,还可以包括:
显示原始描述语言,以及各个工作流引擎的标识,以便用户结合原始描述语言提供描述文件,以及从各个标识中选择目标标识。
其中,原始描述语言,可以为ASL语言。
可以理解的是,本申请实施例中,通过将原始描述语言设置为ASL语言,使得用户可以采用ASL语言生成第二指令内容以及描述文件,由于该语言简洁,且容易理解,且方便用json的形式表达,从而可以方便用户生成第二指令内容以及工作流的描述文件,提高工作流的实现效率。
需要说明的是,显示原始描述语言时,可以显示一种原始描述语言,从而使用户可以结合该原始描述语言生成第二指令内容以及提供描述文件,或者,也可以显示多种原始描述语言,从而使用户可以结合多种原始描述语言中的任一种原始描述语言生成第二指令内容以及提供描述文件。
步骤402,按照与目标标识对应的目标工作流引擎的语言,对第二指令内容以及描述文件进行语言转换,以得到第二目标指令内容和目标描述文件。
其中,第二目标指令内容和目标描述文件,为目标标识对应的目标工作流引擎能够识别的、与目标标识对应的目标工作流引擎的语言对应的指令内容和描述文件。
在示例性实施例中,工作流实现平台中设置有适配器层,且适配器层中包括与各工作流引擎分别对应的适配器,从而在接收到流程部署指令后,可以通过目标标识对应的目标工作流引擎对应的适配器,对指令中的第二指令内容以及描述文件进行语言转换,以得到第二目标指令内容和目标描述文件。
在示例性实施例中,对第二指令内容以及描述文件进行语言转换的过程可以为,获取描述文件的原始描述语言,以及与目标标识对应的目标工作流引擎的语言,确定原始描述语言与目标工作流引擎的语言之间的转换策略,按照转换策略,对第二指令内容以及描述文件进行语言转换,以得到所述第二目标指令内容以及目标描述文件。
步骤403,调用目标工作流引擎按照第二目标指令内容对目标描述文件进行部署处理,以得到目标流程模板。
在示例性实施例中,可以根据目标标识,调用工作流引擎层中与目标标识对应的目标工作流引擎,从而利用该目标工作流引擎按照第二目标指令内容对目标描述文件进行部署处理,以得到目标流程模板。
需要说明的是,本申请实施例中,还可以在接收到流程部署指令后,先查询工作流实现平台的存储层是否存储有与流程部署指令对应的目标流程模板,若有,则可以直接利用存储的目标流程模板进行后续步骤,若没有,再按照流程部署指令通过上述过程生成目标流程模板。
步骤404,接收流程启动指令,其中,流程启动指令包括:第一指令内容、模板标识以及目标标识。
步骤405,按照与目标标识对应的目标工作流引擎的语言,对第一指令内容进行语言转换,以得到第一目标指令内容。
步骤406,调用目标工作流引擎按照第一目标指令内容对模板标识对应的目标流程模板进行实例化处理以及运行处理,以实现工作流。
其中,上述步骤404-406的具体实现过程及原理,可以参考上述实施例的描述,此处不再赘述。
通过先根据接收到的包括第二指令内容、工作流的描述文件以及目标工作流引擎的目标标识的流程部署指令,调用目标工作流引擎按照第二目标指令内容对目标描述文件进行部署处理,以得到目标流程模板,进而在接收到包括第一指令内容、模板标识以及目标标识的流程启动指令时,按照目标工作流引擎的语言,对第一指令内容进行语言转换,以得到第一目标指令内容,再调用目标工作流引擎按照第一目标指令内容对模板标识对应的目标流程模板进行实例化处理以及运行处理,以实现工作流,实现了根据需要在工作流实现平台中部署目标流程模板,从而工作流实现平台中的流程模板可以根据需要扩展,提高了工作流实现的灵活性,且用户在生成流程相关指令时,可以通过简洁、容易理解,且方便用json的形式表达的预设语言进行定义,方便了用户生成流程相关指令,提高了工作流的实现效率。
通过上述分析可知,可以根据流程部署指令,对指令中的第二指令内容和描述文件进行语言转换,得到第二目标指令内容以及目标描述文件,进而调用目标工作流引擎按照第二目标指令内容对目标描述文件进行部署处理,得到目标流程模板,以及根据流程启动指令,按照目标工作流引擎的语言,对流程启动指令中的第一指令内容进行语言转换,以得到第一目标指令内容,进而调用目标工作流引擎对目标流程模板进行实例化处理以及运行处理,以实现工作流。在一种可能的实现形式中,还可以根据接收到的实例查询指令、任务完成指令等其它指令,进行对目标流程模板实例化得到的目标流程实例的管理。下面针对这种情况,结合图5,对本公开提供的工作流实现方法进行进一步说明。
图5是根据本公开第五实施例的工作流实现方法的流程示意图。如图5所示,工作流实现方法,可以包括以下步骤:
步骤501,接收流程启动指令,其中,流程启动指令包括:第一指令内容、模板标识以及目标标识。
步骤502,按照与目标标识对应的目标工作流引擎的语言,对第一指令内容进行语言转换,以得到第一目标指令内容。
步骤503,调用目标工作流引擎按照第一目标指令内容对模板标识对应的目标流程模板进行实例化处理以及运行处理,以实现工作流。
其中,上述步骤501-503的具体实现过程及原理,可以参考上述实施例的描述,此处不再赘述。
步骤504,在接收到携带有目标流程模板的模板标识的流程运行管理指令时,按照目标工作流引擎的语言,对流程运行管理指令进行语言转换,以得到目标流程运行管理指令。
其中,流程运行管理指令,可以为流程实例查询指令、流程结束指令、阶段触发指令、任务完成指令、流程模板查询指令等指令中的任意指令。流程运行管理指令,可以是通过工作流实现平台的接口层中的对应接口接收的。
在示例性实施例中,由于工作流实现平台的接口接收的流程运行管理指令及指令中的目标流程模板的模板标识,为用户通过预设语言定义的,目标工作流引擎可能无法识别该流程运行管理指令及指令中的数据,那么,为了将流程运行管理指令及指令中的数据转换为目标工作流引擎能够识别的指令和数据,可以在接收到携带有目标流程模板的模板标识的流程运行管理指令时,按照目标工作流引擎的语言,对流程运行管理指令进行语言转换,以得到目标工作流引擎能够识别的目标流程运行管理指令。
在示例性实施例中,按照目标工作流引擎的语言,对流程运行管理指令进行语言转换的过程可以为:获取流程运行管理指令的原始描述语言,以及与目标标识对应的目标工作流引擎的语言;确定原始描述语言与目标工作流引擎的语言之间的转换策略;按照转换策略,对流程运行管理指令进行语言转换,以得到目标流程运行管理指令。
步骤505,调用目标工作流引擎执行目标流程运行管理指令,以使目标工作流引擎按照目标流程运行管理指令管理对目标流程模板实例化得到的目标流程实例。
在示例性实施例中,将流程启动指令转换为目标流程启动指令后,即可调用目标工作流引擎执行目标流程运行管理指令,以使目标工作流引擎按照目标流程运行管理指令管理对目标流程模板实例化得到的目标流程实例。比如,目标流程运行管理指令为任务完成指令时,可以按照任务完成指令,结束目标流程模板实例化得到的目标流程梳理。
通过在接收到携带有目标流程模板的模板标识的流程运行管理指令时,按照目标工作流引擎的语言,对流程运行管理指令进行语言转换,以得到目标流程运行管理指令,进而调用目标工作流引擎执行目标流程运行管理指令,以使目标工作流引擎按照目标流程运行管理指令管理对目标流程模板实例化得到的目标流程实例,使得能够根据用户需要对目标流程实例进行管理,且用户在生成流程运行管理指令时,可以通过简洁、容易理解,且方便用json的形式表达的预设语言进行定义,方便了用户生成流程运行管理指令,提高了流程管理的效率。
下面结合图6,对本公开提供的工作流实现装置进行说明。
图6是根据本公开第六实施例的工作流实现装置的结构示意图。
如图6所示,本公开提供的工作流实现装置600,包括:第一接收模块601、第一转换模块602以及第一处理模块603。
其中,第一接收模块601,用于接收流程启动指令,其中,流程启动指令包括:第一指令内容、模板标识以及目标标识;
第一转换模块602,用于按照与目标标识对应的目标工作流引擎的语言,对第一指令内容进行语言转换,以得到第一目标指令内容;
第一处理模块603,用于调用目标工作流引擎按照第一目标指令内容对模板标识对应的目标流程模板进行实例化处理以及运行处理,以实现工作流。
需要说明的是,本实施例提供的工作流实现装置,可以执行前述实施例所述的工作流实现方法。其中,工作流实现装置可以为电子设备,也可以被配置在电子设备中,以提高工作流的实现效率。
其中,电子设备可以是任意能够进行数据处理的计算设备,例如笔记本电脑、智能手机、可穿戴设备等计算设备或者服务器等,本公开对此不作限制。
需要说明的是,前述对于工作流实现方法的实施例的说明,也适用于本公开提供的工作流实现装置,此处不再赘述。
本公开实施例提供的工作流实现装置,首先接收流程启动指令,其中,流程启动指令包括:第一指令内容、模板标识以及目标标识,再按照与目标标识对应的目标工作流引擎的语言,对第一指令内容进行语言转换,以得到第一目标指令内容,再调用目标工作流引擎按照第一目标指令内容对模板标识对应的目标流程模板进行实例化处理以及运行处理,以实现工作流。由此,提高了工作流的实现效率。
下面结合图7,对本公开提供的工作流实现装置进行说明。
图7是根据本公开第七实施例的工作流实现装置的结构示意图。
如图7所示,工作流实现装置700,具体可以包括:第一接收模块701、第一转换模块702以及第一处理模块703,其中,图7中第一接收模块701、第一转换模块702以及第一处理模块703与图6中接收模块601、第一转换模块602以及第一处理模块603具有相同功能和结构。
在示例性实施例中,上述工作流实现装置700,还可以包括:
第二转换模块704,用于在接收到携带有目标流程模板的模板标识的流程运行管理指令时,按照目标工作流引擎的语言,对流程运行管理指令进行语言转换,以得到目标流程运行管理指令;
执行模块705,用于调用目标工作流引擎执行目标流程运行管理指令,以使目标工作流引擎按照目标流程运行管理指令管理对目标流程模板实例化得到的目标流程实例。
在示例性实施例中,上述工作流实现装置700,还可以包括:
第二接收模块706,用于接收流程部署指令,其中,流程部署指令包括:第二指令内容、工作流的描述文件以及目标标识;
第三转换模块707,用于按照与目标标识对应的目标工作流引擎的语言,对第二指令内容以及描述文件进行语言转换,以得到第二目标指令内容和目标描述文件;
第二处理模块708,用于调用目标工作流引擎按照第二目标指令内容对目标描述文件进行部署处理,以得到目标流程模板。
在示例性实施例中,上述工作流实现装置700,还可以包括:
显示模块709,用于显示原始描述语言,以及各个工作流引擎的标识,以便用户结合原始描述语言提供描述文件,以及从各个标识中选择目标标识。
在示例性实施例中,第一转换模块702,包括:
获取单元,用于获取第一指令内容的原始描述语言,以及与目标标识对应的目标工作流引擎的语言;
确定单元,用于确定原始描述语言与目标工作流引擎的语言之间的转换策略;
转换单元,用于按照转换策略,对第一指令内容进行语言转换,以得到第一目标指令内容。
在示例性实施例中,原始描述语言,为亚马逊状态机语言ASL。
需要说明的是,前述对于工作流实现方法的实施例的说明,也适用于本公开提供的工作流实现装置,此处不再赘述。
本公开实施例提供的工作流实现装置,首先接收流程启动指令,其中,流程启动指令包括:第一指令内容、模板标识以及目标标识,再按照与目标标识对应的目标工作流引擎的语言,对第一指令内容进行语言转换,以得到第一目标指令内容,再调用目标工作流引擎按照第一目标指令内容对模板标识对应的目标流程模板进行实例化处理以及运行处理,以实现工作流。由此,提高了工作流的实现效率。
根据本公开的实施例,本公开还提供了一种电子设备、一种可读存储介质和一种计算机程序产品。
图8示出了可以用来实施本公开的实施例的示例电子设备800的示意性框图。电子设备旨在表示各种形式的数字计算机,诸如,膝上型计算机、台式计算机、工作台、个人数字助理、服务器、刀片式服务器、大型计算机、和其它适合的计算机。电子设备还可以表示各种形式的移动装置,诸如,个人数字处理、蜂窝电话、智能电话、可穿戴设备和其它类似的计算装置。本文所示的部件、它们的连接和关系、以及它们的功能仅仅作为示例,并且不意在限制本文中描述的和/或者要求的本公开的实现。
如图8所示,设备800包括计算单元801,其可以根据存储在只读存储器(ROM)802中的计算机程序或者从存储单元808加载到随机访问存储器(RAM)803中的计算机程序,来执行各种适当的动作和处理。在RAM 803中,还可存储设备800操作所需的各种程序和数据。计算单元801、ROM 802以及RAM 803通过总线804彼此相连。输入/输出(I/O)接口805也连接至总线804。
设备800中的多个部件连接至I/O接口805,包括:输入单元806,例如键盘、鼠标等;输出单元807,例如各种类型的显示器、扬声器等;存储单元808,例如磁盘、光盘等;以及通信单元809,例如网卡、调制解调器、无线通信收发机等。通信单元809允许设备800通过诸如因特网的计算机网络和/或各种电信网络与其他设备交换信息/数据。
计算单元801可以是各种具有处理和计算能力的通用和/或专用处理组件。计算单元801的一些示例包括但不限于中央处理单元(CPU)、图形处理单元(GPU)、各种专用的人工智能(AI)计算芯片、各种运行机器学习模型算法的计算单元、数字信号处理器(DSP)、以及任何适当的处理器、控制器、微控制器等。计算单元801执行上文所描述的各个方法和处理,例如工作流实现方法。例如,在一些实施例中,工作流实现方法可被实现为计算机软件程序,其被有形地包含于机器可读介质,例如存储单元808。在一些实施例中,计算机程序的部分或者全部可以经由ROM 802和/或通信单元809而被载入和/或安装到设备800上。当计算机程序加载到RAM 803并由计算单元801执行时,可以执行上文描述的工作流实现方法的一个或多个步骤。备选地,在其他实施例中,计算单元801可以通过其他任何适当的方式(例如,借助于固件)而被配置为执行工作流实现方法。
本文中以上描述的系统和技术的各种实施方式可以在数字电子电路系统、集成电路系统、场可编程门阵列(FPGA)、专用集成电路(ASIC)、专用标准产品(ASSP)、芯片上系统的系统(SOC)、负载可编程逻辑设备(CPLD)、计算机硬件、固件、软件、和/或它们的组合中实现。这些各种实施方式可以包括:实施在一个或者多个计算机程序中,该一个或者多个计算机程序可在包括至少一个可编程处理器的可编程系统上执行和/或解释,该可编程处理器可以是专用或者通用可编程处理器,可以从存储系统、至少一个输入装置、和至少一个输出装置接收数据和指令,并且将数据和指令传输至该存储系统、该至少一个输入装置、和该至少一个输出装置。
用于实施本公开的方法的程序代码可以采用一个或多个编程语言的任何组合来编写。这些程序代码可以提供给通用计算机、专用计算机或其他可编程数据处理装置的处理器或控制器,使得程序代码当由处理器或控制器执行时使流程图和/或框图中所规定的功能/操作被实施。程序代码可以完全在机器上执行、部分地在机器上执行,作为独立软件包部分地在机器上执行且部分地在远程机器上执行或完全在远程机器或服务器上执行。
在本公开的上下文中,机器可读介质可以是有形的介质,其可以包含或存储以供指令执行系统、装置或设备使用或与指令执行系统、装置或设备结合地使用的程序。机器可读介质可以是机器可读信号介质或机器可读储存介质。机器可读介质可以包括但不限于电子的、磁性的、光学的、电磁的、红外的、或半导体系统、装置或设备,或者上述内容的任何合适组合。机器可读存储介质的更具体示例会包括基于一个或多个线的电气连接、便携式计算机盘、硬盘、随机存取存储器(RAM)、只读存储器(ROM)、可擦除可编程只读存储器(EPROM或快闪存储器)、光纤、便捷式紧凑盘只读存储器(CD-ROM)、光学储存设备、磁储存设备、或上述内容的任何合适组合。
为了提供与用户的交互,可以在计算机上实施此处描述的系统和技术,该计算机具有:用于向用户显示信息的显示装置(例如,CRT(阴极射线管)或者LCD(液晶显示器)监视器);以及键盘和指向装置(例如,鼠标或者轨迹球),用户可以通过该键盘和该指向装置来将输入提供给计算机。其它种类的装置还可以用于提供与用户的交互;例如,提供给用户的反馈可以是任何形式的传感反馈(例如,视觉反馈、听觉反馈、或者触觉反馈);并且可以用任何形式(包括声输入、语音输入或者、触觉输入)来接收来自用户的输入。
可以将此处描述的系统和技术实施在包括后台部件的计算系统(例如,作为数据服务器)、或者包括中间件部件的计算系统(例如,应用服务器)、或者包括前端部件的计算系统(例如,具有图形用户界面或者网络浏览器的用户计算机,用户可以通过该图形用户界面或者该网络浏览器来与此处描述的系统和技术的实施方式交互)、或者包括这种后台部件、中间件部件、或者前端部件的任何组合的计算系统中。可以通过任何形式或者介质的数字数据通信(例如,通信网络)来将系统的部件相互连接。通信网络的示例包括:局域网(LAN)、广域网(WAN)、互联网和区块链网络。
计算机系统可以包括客户端和服务器。客户端和服务器一般远离彼此并且通常通过通信网络进行交互。通过在相应的计算机上运行并且彼此具有客户端-服务器关系的计算机程序来产生客户端和服务器的关系。服务器可以是云服务器,又称为云计算服务器或云主机,是云计算服务体系中的一项主机产品,以解决了传统物理主机与VPS服务("Virtual Private Server",或简称"VPS")中,存在的管理难度大,业务扩展性弱的缺陷。服务器也可以为分布式系统的服务器,或者是结合了区块链的服务器。
本公开涉及计算机技术领域,特别涉及信息化管理技术领域。
根据本公开实施例的技术方案,通过在接收到包括第一指令内容、模板标识以及目标标识的流程启动指令后,按照与目标标识对应的目标工作流引擎的语言,对第一指令内容进行语言转换,以得到第一目标指令内容,再调用目标工作流引擎按照第一目标指令内容对模板标识对应的目标流程模板进行实例化处理以及运行处理,以实现工作流,提高了工作流的实现效率。
应该理解,可以使用上面所示的各种形式的流程,重新排序、增加或删除步骤。例如,本发公开中记载的各步骤可以并行地执行也可以顺序地执行也可以不同的次序执行,只要能够实现本公开公开的技术方案所期望的结果,本文在此不进行限制。
上述具体实施方式,并不构成对本公开保护范围的限制。本领域技术人员应该明白的是,根据设计要求和其他因素,可以进行各种修改、组合、子组合和替代。任何在本公开的精神和原则之内所作的修改、等同替换和改进等,均应包含在本公开保护范围之内。
Claims (14)
1.一种工作流实现方法,包括:
接收流程启动指令,其中,所述流程启动指令包括:第一指令内容、模板标识以及目标标识;
按照与所述目标标识对应的目标工作流引擎的语言,对所述第一指令内容进行语言转换,以得到第一目标指令内容;
调用所述目标工作流引擎按照所述第一目标指令内容对所述模板标识对应的目标流程模板进行实例化处理以及运行处理,以实现所述工作流;
在接收流程启动指令之前,还包括:
接收流程部署指令,其中,所述流程部署指令包括:第二指令内容、工作流的描述文件以及所述目标标识;所述工作流的描述文件为描述所述工作流中的各个阶段、各个阶段之间的流转关系的文件;
按照与所述目标标识对应的目标工作流引擎的语言,对所述第二指令内容以及所述描述文件进行语言转换,以得到第二目标指令内容和目标描述文件;
调用所述目标工作流引擎按照所述第二目标指令内容对所述目标描述文件进行部署处理,以得到所述目标流程模板。
2.根据权利要求1所述的方法,其中,所述按照与所述目标标识对应的目标工作流引擎的语言,对所述第一指令内容进行语言转换,以得到第一目标指令内容,包括:
获取所述第一指令内容的原始描述语言,以及与所述目标标识对应的目标工作流引擎的语言;
确定所述原始描述语言与所述目标工作流引擎的语言之间的转换策略;
按照所述转换策略,对所述第一指令内容进行语言转换,以得到所述第一目标指令内容。
3.根据权利要求1所述的方法,其中,在调用所述目标工作流引擎按照所述第一目标指令内容对所述模板标识对应的目标流程模板进行实例化处理以及运行处理之后,还包括:
在接收到携带有所述目标流程模板的模板标识的流程运行管理指令时,按照所述目标工作流引擎的语言,对所述流程运行管理指令进行语言转换,以得到目标流程运行管理指令;
调用所述目标工作流引擎执行所述目标流程运行管理指令,以使所述目标工作流引擎按照所述目标流程运行管理指令管理对所述目标流程模板实例化得到的目标流程实例。
4.根据权利要求1所述的方法,其中,在接收流程部署指令之前,还包括:
显示原始描述语言,以及各个工作流引擎的标识,以便用户结合所述原始描述语言提供所述描述文件,以及从各个标识中选择目标标识。
5.根据权利要求2或4所述的方法,其中,所述原始描述语言,为亚马逊状态机语言ASL。
6.一种工作流实现装置,包括:
第一接收模块,用于接收流程启动指令,其中,所述流程启动指令包括:第一指令内容、模板标识以及目标标识;
第一转换模块,用于按照与所述目标标识对应的目标工作流引擎的语言,对所述第一指令内容进行语言转换,以得到第一目标指令内容;
第一处理模块,用于调用所述目标工作流引擎按照所述第一目标指令内容对所述模板标识对应的目标流程模板进行实例化处理以及运行处理,以实现所述工作流;
第二接收模块,用于接收流程部署指令,其中,所述流程部署指令包括:第二指令内容、工作流的描述文件以及所述目标标识;所述工作流的描述文件为描述所述工作流中的各个阶段、各个阶段之间的流转关系的文件;
第三转换模块,用于按照与所述目标标识对应的目标工作流引擎的语言,对所述第二指令内容以及所述描述文件进行语言转换,以得到第二目标指令内容和目标描述文件;
第二处理模块,用于调用所述目标工作流引擎按照所述第二目标指令内容对所述目标描述文件进行部署处理,以得到所述目标流程模板。
7.根据权利要求6所述的装置,其中,所述第一转换模块,包括:
获取单元,用于获取所述第一指令内容的原始描述语言,以及与所述目标标识对应的目标工作流引擎的语言;
确定单元,用于确定所述原始描述语言与所述目标工作流引擎的语言之间的转换策略;
转换单元,用于按照所述转换策略,对所述第一指令内容进行语言转换,以得到所述第一目标指令内容。
8.根据权利要求6所述的装置,其中,还包括:
第二转换模块,用于在接收到携带有所述目标流程模板的模板标识的流程运行管理指令时,按照所述目标工作流引擎的语言,对所述流程运行管理指令进行语言转换,以得到目标流程运行管理指令;
执行模块,用于调用所述目标工作流引擎执行所述目标流程运行管理指令,以使所述目标工作流引擎按照所述目标流程运行管理指令管理对所述目标流程模板实例化得到的目标流程实例。
9.根据权利要求6所述的装置,其中,还包括:
显示模块,用于显示原始描述语言,以及各个工作流引擎的标识,以便用户结合所述原始描述语言提供所述描述文件,以及从各个标识中选择目标标识。
10.根据权利要求7或9所述的装置,其中,所述原始描述语言,为亚马逊状态机语言ASL。
11.一种工作流实现平台,包括:
依次连接的接口层、适配器层、工作流引擎层和存储层;
其中,所述接口层,用于接收工作流相关的指令;
所述适配器层,包括:每个工作流引擎对应的适配器,用于对所述指令进行语言转换,得到工作流引擎能够识别的指令;
所述工作流引擎层,包括:多个工作流引擎,用于执行对应的指令;
所述存储层,用于存储所述接口层、所述适配器层和所述工作流引擎层接收到的数据以及处理得到的中间数据;
所述接口层包括流程部署接口,所述流程部署接口用于接收携带用户编写的工作流的描述文件的流程部署指令,以使所述工作流实现平台通过执行所述流程部署指令,对所述工作流的描述文件进行部署处理,得到目标流程模板;所述工作流的描述文件为描述所述工作流中的各个阶段、各个阶段之间的流转关系的文件。
12.一种电子设备,包括:
至少一个处理器;以及
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行权利要求1-5中任一项所述的方法。
13.一种存储有计算机指令的非瞬时计算机可读存储介质,其中,所述计算机指令用于使所述计算机执行根据权利要求1-5中任一项所述的方法。
14.一种计算机程序产品,包括计算机程序,所述计算机程序在被处理器执行时实现根据权利要求1-5中任一项所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110192174.2A CN112905270B (zh) | 2021-02-19 | 2021-02-19 | 工作流实现方法、装置、平台、电子设备以及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110192174.2A CN112905270B (zh) | 2021-02-19 | 2021-02-19 | 工作流实现方法、装置、平台、电子设备以及存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN112905270A CN112905270A (zh) | 2021-06-04 |
CN112905270B true CN112905270B (zh) | 2024-05-07 |
Family
ID=76124068
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202110192174.2A Active CN112905270B (zh) | 2021-02-19 | 2021-02-19 | 工作流实现方法、装置、平台、电子设备以及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN112905270B (zh) |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN114445047B (zh) * | 2022-01-29 | 2024-05-10 | 北京百度网讯科技有限公司 | 工作流生成方法、装置、电子设备及存储介质 |
Citations (11)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPH11175644A (ja) * | 1997-12-16 | 1999-07-02 | Hitachi Ltd | 共通のデータベースを持たないワークフローを実現するための制御システム |
CN1558738A (zh) * | 2001-11-22 | 2004-12-29 | ��ʽ���綫֥ | 超声波诊断设备、工作流程编辑系统和控制超声波诊断设备的方法 |
CN1825343A (zh) * | 2004-10-01 | 2006-08-30 | 微软公司 | 创作和执行基于流程且基于约束的工作流的统一模型 |
US7370335B1 (en) * | 2001-11-29 | 2008-05-06 | Vignette Corporation | System and method for providing a public application program interface |
CN102103505A (zh) * | 2011-02-24 | 2011-06-22 | 杭州华三通信技术有限公司 | 工作流界面生成方法及设备 |
CN102542367A (zh) * | 2010-12-10 | 2012-07-04 | 金蝶软件(中国)有限公司 | 基于领域模型的云计算网络工作流处理方法、装置和系统 |
CN107886295A (zh) * | 2017-10-23 | 2018-04-06 | 东软集团股份有限公司 | 流程模板变更处理方法、装置、可读存储介质及电子设备 |
CN111144731A (zh) * | 2019-12-19 | 2020-05-12 | 深圳前海金融资产交易所有限公司 | 工作流的动态实现方法、装置及计算机可读存储介质 |
CN111930539A (zh) * | 2020-07-31 | 2020-11-13 | 北京百度网讯科技有限公司 | 基于标签引擎的任务管理方法、装置、设备及存储介质 |
CN112068936A (zh) * | 2020-07-16 | 2020-12-11 | 石化盈科信息技术有限责任公司 | 一种工作流管理平台及工作流管理系统 |
CN112130823A (zh) * | 2020-09-30 | 2020-12-25 | 广东昆仑信息科技有限公司 | 一种平台开发方法、装置、计算机设备及存储介质 |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7669201B2 (en) * | 2005-05-02 | 2010-02-23 | Intermec Ip Corp. | System and method for common file installation |
-
2021
- 2021-02-19 CN CN202110192174.2A patent/CN112905270B/zh active Active
Patent Citations (11)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPH11175644A (ja) * | 1997-12-16 | 1999-07-02 | Hitachi Ltd | 共通のデータベースを持たないワークフローを実現するための制御システム |
CN1558738A (zh) * | 2001-11-22 | 2004-12-29 | ��ʽ���綫֥ | 超声波诊断设备、工作流程编辑系统和控制超声波诊断设备的方法 |
US7370335B1 (en) * | 2001-11-29 | 2008-05-06 | Vignette Corporation | System and method for providing a public application program interface |
CN1825343A (zh) * | 2004-10-01 | 2006-08-30 | 微软公司 | 创作和执行基于流程且基于约束的工作流的统一模型 |
CN102542367A (zh) * | 2010-12-10 | 2012-07-04 | 金蝶软件(中国)有限公司 | 基于领域模型的云计算网络工作流处理方法、装置和系统 |
CN102103505A (zh) * | 2011-02-24 | 2011-06-22 | 杭州华三通信技术有限公司 | 工作流界面生成方法及设备 |
CN107886295A (zh) * | 2017-10-23 | 2018-04-06 | 东软集团股份有限公司 | 流程模板变更处理方法、装置、可读存储介质及电子设备 |
CN111144731A (zh) * | 2019-12-19 | 2020-05-12 | 深圳前海金融资产交易所有限公司 | 工作流的动态实现方法、装置及计算机可读存储介质 |
CN112068936A (zh) * | 2020-07-16 | 2020-12-11 | 石化盈科信息技术有限责任公司 | 一种工作流管理平台及工作流管理系统 |
CN111930539A (zh) * | 2020-07-31 | 2020-11-13 | 北京百度网讯科技有限公司 | 基于标签引擎的任务管理方法、装置、设备及存储介质 |
CN112130823A (zh) * | 2020-09-30 | 2020-12-25 | 广东昆仑信息科技有限公司 | 一种平台开发方法、装置、计算机设备及存储介质 |
Non-Patent Citations (1)
Title |
---|
面向Hadoop平台的工作流建模与实施;席永涛;李奇原;刘杰;;电脑知识与技术;20120705(19);全文 * |
Also Published As
Publication number | Publication date |
---|---|
CN112905270A (zh) | 2021-06-04 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN112540806B (zh) | 一种小程序页面渲染方法、装置、电子设备及存储介质 | |
CN113342345A (zh) | 深度学习框架的算子融合方法、装置 | |
WO2018036342A1 (zh) | 基于csar的模型文件的可视化设计方法及装置 | |
CN115509522A (zh) | 面向低代码场景的接口编排方法、系统、电子设备 | |
CN114445047A (zh) | 工作流生成方法、装置、电子设备及存储介质 | |
CN112905270B (zh) | 工作流实现方法、装置、平台、电子设备以及存储介质 | |
CN113448570A (zh) | 数据处理方法、装置、电子设备及存储介质 | |
CN116126719A (zh) | 接口测试方法、装置、电子设备及存储介质 | |
CN116009847A (zh) | 代码生成方法、装置、电子设备及存储介质 | |
CN113377360B (zh) | 任务执行方法、装置、电子设备、存储介质和程序产品 | |
CN113691403B (zh) | 拓扑节点配置方法、相关装置及计算机程序产品 | |
CN114237755A (zh) | 应用运行方法、装置、电子设备以及存储介质 | |
CN113110920A (zh) | 区块链系统的运行方法、装置、设备和存储介质 | |
CN114386577A (zh) | 用于执行深度学习模型的方法、设备和存储介质 | |
CN113342413B (zh) | 用于处理组件的方法、装置、设备、介质和产品 | |
CN113360407B (zh) | 函数的定位方法、装置、电子设备及可读存储介质 | |
CN114371889B (zh) | 一种事件配置方法、装置、电子设备及存储介质 | |
CN113378166B (zh) | 调用操作系统的应用程序接口api的方法和装置 | |
CN116561075B (zh) | 动态链接库文件的生成方法、算子的调用方法及装置 | |
CN115222041B (zh) | 用于模型训练的图生成方法、装置、电子设备及存储介质 | |
CN113254469B (zh) | 数据筛选方法及装置、设备和介质 | |
CN118092578A (zh) | 时钟的设置方法及装置、电子设备和存储介质 | |
CN115469887A (zh) | 云原生应用的发布方法及装置、电子设备和存储介质 | |
CN116341663A (zh) | 深度学习推理框架的扩展方法、装置、设备及介质 | |
CN116541090A (zh) | 数据处理方法、装置、设备和介质 |
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 | ||
GR01 | Patent grant | ||
GR01 | Patent grant |