BPMN 2.0

2019-04-14 19:15

第 3 章 BPMN 2.0 3.1. BPMN 2.0是什么呢?

业务流程模型注解(Business Process Modeling Notation - BPMN)是 业务流程模型的一种标准图形注解。这个标准 是由对象管理组(Object Management Group - OMG)维护的。

基本上,BPMN规范定义了任务看起来怎样的,哪些结构可以 与其他进行连接,等等。这就意味着 意思不会被误解。

标准的早期版本(1.2版以及之前)仅仅限制在模型上, 目标是在所有的利益相关者之间形成通用的理解, 在文档,讨论和实现业务流程之上。 BPMN标准证明了它自己,现在市场上许多建模工具 都使用了BPMN标准中的元素和结构。 实际上,现在的jPDL设计器也使用了 BPMN元素。

BPMN规范的2.0版本,当前已经处于最终阶段了, 已经计划不就就会完成,允许添加精确的技术细节 在BPMN的图形和元素中, 同时制定BPMN元素的执行语法。 通过使用XML语言来指定业务流程的可执行语法, BPMN规范已经演变为业务流程的语言, 可以执行在任何兼容BPMN2的流程引擎中, 同时依然可以使用强大的图形注解。

3.2. 历史和目标

jBPM BPMN2的实现是在jBPM 4.0发布之后 在2009年8月,在与社区进行了紧密协作之后启动的。 而后,我们决定了第一个发布版(比如,文档/QA) 涉及一部分BPMN2规范,将在jBPM 4.3发布。

我们的目标是建立一个原生BPMN2运行引擎 (或者说实现'可执行的BPMN2')基于流程虚拟机 (Process Virtual Machine - PVM)。 注意,这个版本的主要目标是原生可执行, 不是图形注解 - 但是我们清楚 对于未来的版本是很重要的。

如果用户已经了解了jBPM,就会发现

? ? ? ?

配置结构保持不变

API与已经存在的完全一样或者很类似

测试BPMN2流程也可以使用常用的java测试框架 数据库表结构保持不变

所以,总体来说,我们的主要目标是保持所有在jBPM上好的事情, 加强它们,使用一个标准的流程语言。

3.3. JPDL vs BPMN 2.0

第一个问题可能是,很正当的,映入脑海的是, 为什么已经有了jPDL还要实现BPMN2。它们两个语言 的目标都是定义可执行的业务流程。从高层次来看, 两个语言是等效的。主要的区别是 BPMN2是“厂商中立”的,你可以使用标准, 而jPDL是绑定在jBPM上的(虽然会有一些争论 绑定在开源语言厂商比如jPDL 和绑定在闭源产品)。

在jBPM中,两个语言实现都是建立在jBPM流程虚拟机上的 (PVM)。这意味着两个语言共享通用功能 (持久化,事务,配置,也有基本流程结构,等等)。 结果就是,对jBPM核心的优化 会对两个语言有益。依靠PVM,BPMN2实现 建立在基础上,已经在过去证明了它自己, 并拥有了很大的最终用户社区。 当执行语言,把它们相互比较的时候, 下面几点必须纳入考虑:

? ?

? ? ?

BPMN2是基于被BPM工业接受的一个标准。

BPMN2是与实现无关的。这一点的缺点是集成java技术 jPDL总会更早。 所以,从java开发者的角度,jPDL更简单,感觉更自然 (一些BPEL/WSDL的“层次”也在BPMN中)。

jPDL的一个目标是XML可读,BPMN2流程在 一定程度上也是可读的,但是工具和更多规范的细节 会要求实现同等级的 生产力。

java开发者可以很快学会jPDL,因为他们很了解jPDL语言, 会发现实用工具有时候很麻烦, 语言本身也过于复杂了。

BPMN2包含一个很大的描述结构的集合,在规范中。 然而,对接口代码的绑定在规范中是开放的 (与XPDL相比),即使WSDL通常会被默认使用。 这意味着流程的可移植性丧失了, 当我们把流程移植到一个引擎上,而这个引擎不支持同样的绑定机制。 比如,调用java类通常是jBPM的默认实现 的绑定方式。

很自然的,因为政治原因,BPMN2规范发展的会比较慢。 jPDL就可以快速变化,和新技术进行集成, 当他们发布的时候, 与BPMN2相比可以加快步伐进行演化。 当然,因为两个都建立在同一个PVM上,jPDL中的逻辑 也可以一直到BPMN2上, 作为一个扩展,不会出现很多麻烦。

3.4. Bpmn 2.0 执行

BPMN2规范定义了非常丰富的语言,为建模和执行业务流程。 然而,也意味着它非常困难总览BPMN2可能是怎样 为了简化这种情况,我们决定把 BPMN2结构分为三个等级。 区分的方式主要基于Bruce Silver写的 'BPMN method and Style'这本书(http://www.bpmnstyle.com/), Dr. Jim Arlow的培训资料( http://www.slideshare.net/jimarlow/introductiontobpmn005), 'How much BPMN do you

need'( http://www.bpm-research.com/2008/03/03/how-much-bpmn-do-you-need/), 和我们自己的经验。 我们定义了三种BPMN2结构分类:

基本:这个分类的结构很直接 并且容易了解。这个分类的结构可以用来为 简单的业务流程建模。 ? 高级:包含更强大或更复杂的结构, 这些都提高了建模和执行语法的学习曲线。 业务流程的主要目标是使用这个 和之前的分类来实现结构。 ? 复杂:这个分类的结构用来实现罕见的情况, 或者它们的语法难以理解。

?

3.5. 配置

在你的应用中使用BPMN 2.0是很简单的:只要把下面一行 加入jbpm.cfg.xml文件。

流程引擎是根据定义文件的后缀来区分流程定义的。 对于BPMN 2.0,使用*.bpmn.xml后缀 (jPDL使用*.jpdl.xml后缀)。

3.6. 实例

发布中包含的例子也包含了下面章节中 讨论的每个结构的实例。查看BPMN 2.0的流程实例 和测试用例, 在org.jbpm.examples.bpmn.* 包下。

参考用户指南,第二章(安装),研究一下如何导入实例。 查看章节'导入实例'。

3.7. 流程根元素

一个BPMN 2.0 XML流程的根是definitions元素。 在命名状态,子元素会包含真正的业务流程定义。 每个process子元素 可以拥有一个id和 name。一个空的BPMN 2.0业务流程 看起来像下面这样。也要注意把BPMN2.xsd放在classpath下, 来启用XML自动补全。 如果一个process元素定义了id,它会作为业务流程的key使用 (比如,启动流程可以通过调用

executionService.startProcessInstanceByKey(\, 否则jBPM引擎会创建一个唯一流程key(与jPDL相同)。

3.8. 基本结构

3.8.1. 事件

与活动和网关一起,事件用来在实际的每个业务流程中。 事件让业务建模工具用很自然的方式描述业务流程,比如 '当我接收到客户的订单,这个流程就启动', '如果两天内任务没结束,就终止流程' 或者'当我收到一封取消邮件,当流程在运行时, 使用子流程处理邮件'。注意典型的业务 通常使用这种事件驱动的方式。人们不会硬编码顺序创建, 但是他们倾向于使用在他们的环境中发生的事情(比如,事件)。 在BPMN规范中,描述了很多事件类型,为了覆盖可能的事情, 在业务环境中可能出现的情况。

3.8.2. 事件:空启动事件

一个启动事件说明了流程的开始(或子流程)。图形形式,它看起来 是一个圆(可能)内部有一个小图标。图标指定了事件的实际类型 会在流程实例创建时被触发。

空启动事件画出来是一个圆,内部没有图标,意思是 这个触发器是未知或者未指定的。jPDL的开始活动基本是一样的语法。 流程实例的流程定义包含一个空启动事件, 可以使用executionService的API调用创建。

一个空开始事件像下面这样定义。id是必填的,name是可选的。

结束事件指定了流程实例中一个流程路径的结束。 图形上,它看起来就是一个圆 拥有厚边框(可能) 内部有小图标。 图标指定了结束的时候 会执行哪种操作。

空结束事件画出来是一个圆,拥有厚边框,内部没有图标, 这意味着当流程到达事件时,不会抛出任何信号。 jPDL中的结束事件与空结束事件语义相同。 空结束事件可以像下面一样定义,id是必填的,name是可选的。

这个流程对应的可执行XML像这样 (忽略声明用的definitions根元素) 现在可以通过调用startProcessInstanceXXX操作, 创建一个流程实例。


BPMN 2.0.doc 将本文的Word文档下载到电脑 下载失败或者文档不完整,请联系客服人员解决!

下一篇:安踏鞋及服装尺码对照表

相关阅读
本类排行
× 注册会员免费下载(下载后可以自由复制和排版)

马上注册会员

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: