JBoss jBPM2.0工作流引擎完全解密

Jbpm介绍
1, 项目介绍

项目是2003年1月由Tom Baeyenssourceforge创建。Tom BaeyensJSR207Process Definition for Java)的专家组成员

项目的URL http://jbpm.org

项目2004年10月加入jboss组织,项目更名为JBoss jBPM
2, jbpm工作流系统介绍
jbpm是轻量级,可扩展的工作流管理系统。Jbpm的业务流程的定义是用jPdl( Process definition language)来描述的。系统的原理是:由流程管理员装入流程,用户或者系统执行流程中的步骤,jbpm引擎负责维护流程的状态,日志以及执行流程中定义的自动动作。用用例图描述如下:
10dc8fa51c6.jpg
3, 项目部署(Tomcat+SQLServer)
a)          环境
JBoss jBPM 2.0, Tomcat 4.1.31, SQLServer 2000,ant 1.5.4
b)         步骤
1, 解压jboss-jbpm-2.0.zip,路径为[jbpm_home]
2, 添加jdbc driver到[jbpm_home]/lib/hibernate
3, 在[jbpm_home]/.classpath文件中添加jdbc driver
4, 在[jbpm_home]/ web/src/jbpm.war/WEB-INF/classes/jbpm.properties文件中hibernate使用SQLServer的jdbc配置
5, 重新编译和打包,在[jbpm_home]目录中执行ant
6, 发布流程, 修改[jbpm_home]/build.xml文件,在38行修改为     <ant antfile="web/build.xml" target="deploy.process.archives" inheritall="false" />
7, 在[jbpm_home]目录中执行ant ,现在 数据库已经建立,并且流程已经初始化,这里有个bug需要修改,把数据库中创建的表 JBPM_FILE的bytes的类型修改为image
8, 部署web应用, 拷贝[jbpm_home]/web/target/jbpm.war到[tomcat_home]/webapps
9, 启动tomcat
10,               拷贝commons-digester.jar, commons-fileupload.jar, jakarta-oro.jar,文件到[tomcat_home]/webapps/jbpm/WEB-INF/lib目录
11,               打开浏览器 输入地址 http://localhost:8080/jbpm
12, 恭喜部署成功
4, jPdl介绍

 

jPdl描述的是流程的过程,是通过状态表示,流程由
<!ELEMENT start-state ( description?, transition+ ) >
<!ELEMENT state ( description?, assignment?, action*, transition+ ) >
<!ELEMENT process-state ( description?, delegation, action*, transition+ ) >
<!ELEMENT decision ( description?, delegation, action*, transition+ ) >
<!ELEMENT fork ( description?, delegation?, action*, transition+ ) >
<!ELEMENT join ( description?, delegation?, action*, transition ) >
<!ELEMENT end-state EMPTY >
几个元素组成。流程的走向由transition元素指定。
Start-state就是开始节点
State就是流程的活动
Process-state就是子流成
Decision是判断节点
Fork是分支节点
Join是联合节点(注意fork和join必须成对出现)
End-state是结束节点

 

State中定义参与者,state是流程的主要环节,必须要人机参与处理,调用ExecutionService . endOfState ()来结束活动,使jBPM引擎流转。action是用来扩展的,action的定义如下

 

<!ELEMENT action ( delegation ) >
<!ATTLIST action event-type (process-start|process-end|state-enter|state-leave|state-after-assignment|milestone-enter|milestone-leave|decision-enter|decision-leave|process-state-enter|process-state-leave|fork-enter|fork-every-leave|join-every-enter|join-leave|transition) #IMPLIED>
<!ELEMENT delegation ( #PCDATA ) >
<!ATTLIST delegation class CDATA #REQUIRED>

 

state的Action支持state-enter,state-leave和state-after-assignment事件,可以对每个事件处理不同业务。实现Action必须实现接口org.jbpm.delegation. ActionHandler.
 process-state, decision, fork, join跟Action一样都可以支持事件机制
process,fork,decision,join是jBPM引擎自动完成的,完成执行的操作就是节点的delegation里面注册的类. 如果没有就是用系统默认的。

 

5, 工作流引擎与应用的接口原理

 

应用调用ExecutionService. StartProcessInstance()启动流程,引擎产生任务。等待任务的所有者调用ExecutionService. endOfState ()指令来完成任务。当endOfState指令被调用后,引擎就进行运算产生的新的任务,然后继续等待endOfState指令的调用直到流程结束。
引擎只对State产生任务,对其他的节点比如:process-state,fork,decision,join都不产生任务。只对他们进行运算,执行每个节点的Delegation和Action.

 

6, JBPM工作流引擎的优点
a)          轻巧,使用Hibernate实现
b)         扩展性好,支持各种事件和节点的扩展,
c)         工作流原理和实现简单,代码容易维护
d)         支持变量
e)          支持子流成
f)          参与者与应用集成非常简单
g)         项目加入jboss组织,成长乐观
7, JBPM工作流引擎的弱点
a)          流程图形画定义工具太弱
b)         没有图形画的流程监控工具
c)         join/fork必须成对定义
d)         复杂的流程定义需要自己实现接口
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值