揭秘揭秘jbpm流程引擎内核设计思想及构架流程引擎内核设计思想及构架
火龙果软件工程技术中心
1 前言
2 阅读本篇的基础准备
2.1 概念的基础
2.2 环境的基础
3 什么是流程引擎内核?
4 引擎内核所关注的四个主要问题
4.1 模型与定义对象
4.2 调度机制与算法
4.3 执行机制与状态
4.4 实例对象与执行环境
5 jbpm,“精简”的开源流程引擎
6 jBpm流程模型与定义对象
6.1 首先解决如何形式化描述一个流程的问题
6.2 抽象的节点(Node)和转移(Transition)
6.3 流程:节点与转移的组合
6.4 节点的类型和扩展
7 jBpm的过程调度机制
7.1 吸纳自Petri Net思想
7.2 Token的推进
7.3 非常简单的调度机制
8 jBpm的过程执行机制
8.1 执行机制
8.2 分支处理
9 jBpm内核结构与实例对象
10 后记
1 前言前言
流程引擎内核仅是“满足Process基本运行”的最微小结构,而整个引擎则要复杂很多,包括“状态存储”、“事件处理”、“组织适
配”、“时间调度”、“消息服务”等等外围的服务性功能。引擎内核,仅包含最基本的对象和服务,以及用于解决流程运行问题的
调度机制和执行机制。
如果,你掌握了一个流程引擎的灵魂,你才有能力理解它的全部。否则,一个引擎对你来说,可能只是一个复杂的结构,丰
富多彩API、令人眼花缭乱的“功能”和“服务”而已。
本身工作流这个领域就是一个很“狭窄”的领域,国内的厂商也不是很多,其中有部分实现技术并不弱。但可能涉于安全等因
素,并没有多少技术人员探讨“深度的工作流技术实现问题”。而广大的开发爱好者却还在花费大量的时间在摸索“如何理解工作
流、如何应用工作流”。 所以在此之前,国内尚未有一篇技术文章探讨工作流引擎内核的实现,当然也没有探讨jBpm引擎内核
的文章了。在www.javaeye.com 技术站点和我的blog(http://blog.csdn.net/james999)上有几篇专门探讨jbpm应用的文章,
对于初步想了解如何使用jbpm的读者来说,值得看看。
对于这方面的技术分享,开源是个不错的突破口。
本篇就是以jBpm为实例,来诠释工作流引擎的内核设计思路和结构。但是这仅仅是从jBpm的实现角度来辅助大家理解,因
为工作流引擎内核的设计、实现是有很多方式:这会因所选的模型、调度算法、推进机制、状态变迁机制、执行机制等多方面
的不一样,而会差别很大。比如基于Activity Diagram模型的jBpm和基于FSM模型的OSWorkflow引擎内核之间就有很大的差
别。
相比较而言,jBpm的模型比较复杂,而引擎内核实现的比较“精简”,非常便于大家“由浅入深的理解”。
2 阅读本篇的基础准备阅读本篇的基础准备
2.1 概念的基础概念的基础
本文的读者群主要是面向有一定工作流基本概念的开发人员。所以本文认为你已经具备了如下基本工作流知识:
(1) 初步了解工作流系统结构。比如理解工作流引擎在工作流系统中所处的位置和作用
(2) 对流程定义(Process Definition)和流程实例(Process Instance)相关对象有所了解。比如理解Process Instance
代表什么,工作项(WorkItem)代表什么。
2.2 环境的基础环境的基础
在阅读本篇的时候,如果你已经搭建了一套jbpm的开发环境,那么将有助于你更容易理解本篇的很多内容,也便于实际体
验代码。从www.jbpm.org官方网站下载jbpm-starters-kit开发包,按照其参考手册,可以很容易在eclipse开发环境中建立项
目,效果图类似如下: