CN114489578A - 一种基于bpm对bpmn模型实现的方法 - Google Patents
一种基于bpm对bpmn模型实现的方法 Download PDFInfo
- Publication number
- CN114489578A CN114489578A CN202111602006.2A CN202111602006A CN114489578A CN 114489578 A CN114489578 A CN 114489578A CN 202111602006 A CN202111602006 A CN 202111602006A CN 114489578 A CN114489578 A CN 114489578A
- Authority
- CN
- China
- Prior art keywords
- flow
- model
- bpmn
- bpm
- instance
- 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
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/20—Software design
- G06F8/22—Procedural
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- General Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Management, Administration, Business Operations System, And Electronic Commerce (AREA)
Abstract
本发明公开了一种基于BPM对BPMN模型实现的方法,包括以下步骤:步骤一:BPMN流程设计器的兼容适配;步骤二:流程模型的持久化;步骤三:流程模型的解析;步骤四:流程模型的实例化。实例化需要建立在源引擎之上,实例化的流程模板即为流程实例,流程实例是运行在源引擎上的实例,以空流程的形式初始化。这一步在业务上即为流程的发起;步骤五:流程实例的运行实现,本发明的基本方法是通过源引擎提供的动态流转的模式,在此基础上扩展,实现具有BPMN能力的API,最终能显著扩展业务实施人员的流程配置方式,增加流程的表现力,降低实施成本,也完全新增了循环流程的流转功能。
Description
技术领域
本发明涉及BPM平台技术领域,具体为一种基于BPM对BPMN模型实现的方法。
背景技术
BPMN2.0规范定义了流程模型的三类基本要素,Flow Objects流对象、Data数据、Connecting Objects连接对象和用于解释流程的辅助要素Swim-lanes泳道和Artifacts工件。由此共同组成了BPMN模型BPMN2-Diagram,该模型是一种图模型,最重要的模型元素包括流对象中的Activities活动、Gateway网关和Event事件以及连接对象中的SequenceFlow序列流,活动是流程中的节点,序列流则是代表流程中将被执行的活动的执行顺序,网关则是辅助流程流向以分支或是聚合的方式工作。虽然流程需要满足有一个开始事件Start Event和一个结束事件End Event,但在基本要素的构建规则基础上,以BPMN规范构建的图模型满足数学上标准图模型的任何要素,可以构建出具有复杂拓扑结构的图实例,包括星型拓扑、环形拓扑、总线型拓扑、树形拓扑、网状拓扑、混合拓扑结构。以下以一个BPMN模型实例为例,见图1。
现目前的BPM的工作流引擎并不具备BPMN的复杂模型的拓扑能力,在模型上只能满足从前到后加上分支系统的顺序执行的能力,无法解决环形拓扑结构的需求,在业务上常用的流程结构基本是复杂的混合拓扑,期间一定包含环形结构,如果在模型上就不支持这种能力,就需要通过繁琐的业务标注和其他流程反向的功能模拟实现,见图2。因此,亟待一种扩展引擎能力的技术来解决无法满足现有业务上需求。
发明内容
本发明的目的在于提供一种基于BPM对BPMN模型实现的方法,以解决上述背景技术中提出的问题。
为实现上述目的,本发明提供如下技术方案:一种基于BPM对BPMN模型实现的方法,包括以下步骤:
步骤一:BPMN流程设计器的兼容适配;
步骤二:流程模型的持久化;
步骤三:流程模型的解析;
步骤四:流程模型的实例化;
步骤五:流程实例的运行实现;
步骤六:流程实例的结束。
优选的,所述步骤一中系统需要对具有BPMN模型规范的设计器进行适配兼容。
优选的,所述步骤二中的流程模型的持久化的方式根据数据库的类型和具体系统需求,包括性能或者可读性选择存储成JSON、XML或是二进制序列。
优选的,所述步骤二中的流程模型的持久化的最终对象不限于数据库类型,包括关系型数据库,非关系型数据库。
优选的,所述步骤三中新引擎需要对序列化的流程模型进行解析,反序列化为系统可以识别并处理的对象结构。
优选的,所述步骤四实例化需要建立在源引擎之上,实例化的流程模板即为流程实例,流程实例是运行在源引擎上的实例,以空流程的形式初始化。
优选的,所述步骤五BPMN模型实例的运行依赖于实例化的流程模型,即流程模板,每向后一步的目标模型活动依赖于当前被激活的活动,目标活动与当前活动通过序列流连接,通过网关的辅助,目标活动可以存在多个,基于应用上的设计,当先活动可以手动或者自动流转到后序的目标活动,通过模型间的关系可以计算出所有需要被激活的目标活动,目标活动需要包含有需要生成源引擎节点的全部信息,通过碎片化的信息持久化方式与模型节点关联;至此,计算出全部的源引擎节点信息,以动态流转的方式激活后续源引擎流程实例节点。
优选的,所述步骤六通过当前活动和模型间的关系可以计算出后序所有需要被激活的活动,在某些条件下,到达结束事件并执行完事件任务后,流程实例完成整个生命周期。
与现有技术相比,本发明的有益效果是:本发明提供的基于BPM工作流引擎构建具有满足BPMN规范的工作流引擎系统,以一种较低成本的方式,实现了BPMN工作流引擎;业务实施人员能够以更直观的方式,设计出满足复杂业务流向的流程模型,降低实施成本,并且实现了源引擎无法实现循环流程的问题。
附图说明
图1为BPMN模型工作流结构示意图;
图2为源引擎流程结构示意图;
图3为本发明流程示意图;
图4为本发明引擎的工作架构图;
图5为实施流程示意图;
图6为含有多种拓扑结构的实施流程实例示意图。
具体实施方式
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
图1与图6的设计器均不代表最终设计器的样式,设计器可以自行对流程进行扩展定义和补充,包含了对网关的隐藏设计,不是指示仅具有图中展示元素的最终效果,因此不能理解为对本发明的限制。
本发明提供如下技术方案:一种基于BPM对BPMN模型实现的方法,包括以下步骤:
步骤一:BPMN流程设计器的兼容适配;
步骤二:流程模型的持久化;
步骤三:流程模型的解析;
步骤四:流程模型的实例化;
步骤五:流程实例的运行实现;
步骤六:流程实例的结束。
本发明中,步骤一中系统需要对具有BPMN模型规范的设计器进行适配兼容。
本发明中,步骤二中的流程模型的持久化的方式根据数据库的类型和具体系统需求,包括性能或者可读性选择存储成JSON、XML或是二进制序列。
本发明中,步骤二中的流程模型的持久化的最终对象不限于数据库类型,包括关系型数据库,非关系型数据库。
本发明中,步骤三中新引擎需要对序列化的流程模型进行解析,反序列化为系统可以识别并处理的对象结构。
本发明中,步骤四实例化需要建立在源引擎之上,实例化的流程模板即为流程实例,流程实例是运行在源引擎上的实例,以空流程的形式初始化。
本发明中,步骤五BPMN模型实例的运行依赖于实例化的流程模型,即流程模板,每向后一步的目标模型活动依赖于当前被激活的活动,目标活动与当前活动通过序列流连接,通过网关的辅助,目标活动可以存在多个,基于应用上的设计,当先活动可以手动或者自动流转到后序的目标活动,通过模型间的关系可以计算出所有需要被激活的目标活动,目标活动需要包含有需要生成源引擎节点的全部信息,通过碎片化的信息持久化方式与模型节点关联;至此,计算出全部的源引擎节点信息,以动态流转的方式激活后续源引擎流程实例节点。
本发明中,步骤六通过当前活动和模型间的关系可以计算出后序所有需要被激活的活动,在某些条件下,到达结束事件并执行完事件任务后,流程实例完成整个生命周期。
本发明方法,让复杂的流程模型通过高效的BPMN规范模型实现,增加了流程的无限可循环流转特性,流程活动节点的任意指向特性,增强了流程的灵活性,使流程有更为直观的可理解性,使得流程管理也更高效,并且具备更高的可维护性。
综上所述,本发明提供的基于BPM工作流引擎构建具有满足BPMN规范的工作流引擎系统,以一种较低成本的方式,实现了BPMN工作流引擎;业务实施人员能够以更直观的方式,设计出满足复杂业务流向的流程模型,降低实施成本,并且实现了源引擎无法实现循环流程的问题。
需要说明的是,在本文中,诸如术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同要素。
对于本领域技术人员而言,显然本发明不限于上述示范性实施例的细节,而且在不背离本发明的精神或基本特征的情况下,能够以其他的具体形式实现本发明。因此,无论从哪一点来看,均应将实施例看作是示范性的,而且是非限制性的,本发明的范围由所附权利要求而不是上述说明限定,因此旨在将落在权利要求的等同要件的含义和范围内的所有变化囊括在本发明内。不应将权利要求中的任何附图标记视为限制所涉及的权利要求。
Claims (8)
1.一种基于BPM对BPMN模型实现的方法,其特征在于:包括以下步骤:
步骤一:BPMN流程设计器的兼容适配;
步骤二:流程模型的持久化;
步骤三:流程模型的解析;
步骤四:流程模型的实例化;
步骤五:流程实例的运行实现;
步骤六:流程实例的结束。
2.根据权利要求1所述的一种基于BPM对BPMN模型实现的方法,其特征在于:所述步骤一中系统需要对具有BPMN模型规范的设计器进行适配兼容。
3.根据权利要求1所述的一种基于BPM对BPMN模型实现的方法,其特征在于:所述步骤二中的流程模型的持久化的方式根据数据库的类型和具体系统需求,包括性能或者可读性选择存储成JSON、XML或是二进制序列。
4.根据权利要求1所述的一种基于BPM对BPMN模型实现的方法,其特征在于:所述步骤二中的流程模型的持久化的最终对象不限于数据库类型,包括关系型数据库,非关系型数据库。
5.根据权利要求1所述的一种基于BPM对BPMN模型实现的方法,其特征在于:所述步骤三中新引擎需要对序列化的流程模型进行解析,反序列化为系统可以识别并处理的对象结构。
6.根据权利要求1所述的一种基于BPM对BPMN模型实现的方法,其特征在于:所述步骤四实例化需要建立在源引擎之上,实例化的流程模板即为流程实例,流程实例是运行在源引擎上的实例,以空流程的形式初始化。
7.根据权利要求1所述的一种基于BPM对BPMN模型实现的方法,其特征在于:所述步骤五BPMN模型实例的运行依赖于实例化的流程模型,即流程模板,每向后一步的目标模型活动依赖于当前被激活的活动,目标活动与当前活动通过序列流连接,通过网关的辅助,目标活动可以存在多个,基于应用上的设计,当先活动可以手动或者自动流转到后序的目标活动,通过模型间的关系可以计算出所有需要被激活的目标活动,目标活动需要包含有需要生成源引擎节点的全部信息,通过碎片化的信息持久化方式与模型节点关联;至此,计算出全部的源引擎节点信息,以动态流转的方式激活后续源引擎流程实例节点。
8.根据权利要求1所述的一种基于BPM对BPMN模型实现的方法,其特征在于:所述步骤六通过当前活动和模型间的关系可以计算出后序所有需要被激活的活动,在某些条件下,到达结束事件并执行完事件任务后,流程实例完成整个生命周期。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202111602006.2A CN114489578A (zh) | 2021-12-24 | 2021-12-24 | 一种基于bpm对bpmn模型实现的方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202111602006.2A CN114489578A (zh) | 2021-12-24 | 2021-12-24 | 一种基于bpm对bpmn模型实现的方法 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN114489578A true CN114489578A (zh) | 2022-05-13 |
Family
ID=81495313
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202111602006.2A Pending CN114489578A (zh) | 2021-12-24 | 2021-12-24 | 一种基于bpm对bpmn模型实现的方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN114489578A (zh) |
-
2021
- 2021-12-24 CN CN202111602006.2A patent/CN114489578A/zh active Pending
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN109766097A (zh) | Ui生成方法、装置、电子设备及计算机可读存储介质 | |
Cavalieri et al. | Integration of IEC 61850 SCL and OPC UA to improve interoperability in Smart Grid environment | |
CN101082970A (zh) | 政务审批工作流引擎系统的实现方法 | |
CN103886398A (zh) | 一种跨系统异构环境下的业务监控方法和系统 | |
CN113721892A (zh) | 领域建模方法、装置、计算机设备和存储介质 | |
WO2021003843A1 (zh) | 工业园区综合能源系统的分层分布式协调控制时序方法 | |
CN116661766A (zh) | 一种基于人工智能的软件低代码开发方法 | |
CN110618810A (zh) | 一种基于元数据驱动的多样化服务的混合编排方法 | |
CN104954232A (zh) | 网络中服务组合的方法及装置 | |
CN114489578A (zh) | 一种基于bpm对bpmn模型实现的方法 | |
WO2004038612A1 (ja) | 連鎖したジョインテーブルのツリー構造への変換方法、および、変換プログラム | |
WO2021147876A1 (zh) | 内存资源原地共享决策系统及其方法 | |
CN103971225A (zh) | 一种工作流动态扩展方法及系统 | |
CN108171396B (zh) | 检测和删除Petri网业务流程中结构冗余的方法及装置 | |
CN115454383A (zh) | 一种软件定义汽车服务开发的流程和实施方法 | |
CN102393820A (zh) | 一种楼宇监控系统控制逻辑的实现方法 | |
Wu et al. | Knowledge map application of business-oriented problem solving | |
CN115062550B (zh) | 一种基于端口反向生成的组合建模方法 | |
CN112651715A (zh) | 跨组织业务协同流程图谱构建方法、装置和设备 | |
CN102438325B (zh) | 基于认知无线终端重构系统的资源调度方法 | |
CN110414939A (zh) | 一种基于组件元素配置渲染表单及保存表单数据的方法 | |
Wang et al. | CIM modeling for market management systems | |
CN103714035A (zh) | 一种用于集成环境的多层软件总线结构 | |
Hong et al. | A resolution converter for multi-resolution modeling/simulation on HLA/RTI | |
CN107609845A (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 |