`

谈谈JBPM几种节点的不同用法及适合的应用场景

阅读更多

     最近都在学习JBPM的东西,发现用起来还真不是那么的简单。先别说怎么用JBPM来处理流程,单单在建立流程定义的时候就大有学问所在。我们究竟是选择何种节点呢,Node,Task Node,State?

  这就要看你的具体应用而定了,因为每种节点的特点不同。先看看各种节点的说明:

state(状态):
State节点也叫手工节点,进入到这种节点,整个流程的执行就会中断。直到系统外参与者发起继续执行的命令,即调用signal或end方法,业务程序实例的执行才能够继续下去。

node(自动节点):

这种节点和State相反,也称自动节点。当业务程序实例执行到这个节点,不会停止执行。而是会继续往下执行。如果该节点存在多个离开转向。那么,就会执行其中的第一个离开转向,在Node状态中,不需要外部参与者的参与,业务流程的这个部分是自动的、即时完成的。

task-node (任务节点):
其性质和node节点一样,在没有task的时候,也都是自动执行,不等待。task-node被归类为一个等待节点,是指在task-node中的task列表中的task没有全部执行完之前,它会一直等待。Task可以在task-node节点下定义,也可以挂在process-definition节点下。最普遍的方式是在task-node节点下定义一个或多个任务。默认情况下,流程在task-node节点会处于等待状态,直到所有的任务被执行完毕。Task的执行是按顺序执行的,任务都完成后,token仍然不会指向后面的节点;需要自己手动调用processInstance.signal()才会驱动流程到下面的节点

 

   一般在实际应用场景中,通常只有上面三种节点选择上不好确定,通过上面三种节点的特点的认识。应该就大致有了注意了吧。

  比如前几篇博文中介绍的那个文章审批系统,有几个朋友问我为什么用<state>节点而不用node,task node?下面我把图也附上来说明下问题吧:

&lt;state>适合的应用场景

如图的业务,我们来分析下,文章审批,就是文章的层层审批,一审完成到二审,二审完成到三审。。。,每个过程用一个<state>来表示。文章到达一个审批级别时,审批员进行审批,然后调用signal();使流程到达下一个<state>.然后下一个审批也同样处理。假设我们把<state>换成<node>或<task node>(无委派任务的task node),那么,因为他们都是自动节点了,流程一起动就一口气的自动执行到了结束节点,我们怎么来实现层层审批啊?

      正好在网上看到了个请假的审批程序。download下来研究了一下,发现写的的确不错。把JBPM 60%的精髓都用上了,里面用到的是<task node>节点。对于来理解几种节点的用法很有启发。记得好像是在CSDN上下的代码,里面也没有详细的说明,没有jar。我也小小的修改了下,同时写了个演示如何显示流程图的页面(很简单的例子,惭愧)。把项目上传到附件中供下载学习。

   我看过代码后,跟踪了整个流程的执行。正好也应征了<task node>的特点。因为项目里的每个<task node>中都定义了<task>,所以<task node>中的任务执行完成后,就会停止来等待外部的触发使流程继续执行。

   下面是我分析的图:

 红色的横线就是任务执行完停止的地方,然后外部调用相应的触发动作,才继续往下执行的。

    因为本人也刚刚研究JBPM不久,对JBPM也不是很熟悉。以上仅仅为个人的理解,写下博文只是记录下自己的学习感想。

    O(∩_∩)O ~

10
2
分享到:
评论
5 楼 sdm_seven 2013-01-05  
这个没数据库
4 楼 lukun_java 2011-09-21  
运行测试一下看看结果,上面讲的确实通俗易懂
3 楼 zpchen 2009-01-06  
darvsum 写道

zpchen 你好!这段时间一直在研究你的这几篇文章,仍然有些地方不明白,请指导一下.下面是QingJiaWeb项目的工作流定义片段: &lt;decision name="Deci_IsChiefHere"&gt; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;handler class="com.myrequest.decision.IsChiefHereDecisionHandler"/&gt; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;transition name="Tr_Chief" to="TN_ChiefDecide"&gt;&lt;/transition&gt; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;transition name="Tr_Boss" to="TN_BossDecide"&gt;&lt;/transition&gt; &nbsp;&nbsp; &lt;/decision&gt; 这段好明白,在IsChiefHereDecisionHandler中有判断知道应该执行"Tr_Chief",还是执行"Tr_Boss"。但在fork 和 task-node中并没有判断啊,那这么确定流程的转向呢? &lt;fork name="Fork_request"&gt; &nbsp;&nbsp;&nbsp;&nbsp; &lt;transition name="Tr_Cancel"to="TN_RequesterCancel"&gt; &lt;/transition&gt; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;transition name="Tr_Request" to="Deci_IsChiefHere"&gt; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;action name="Ac_GetChiefState" class="com.myrequest.action.GetChiefStateActionHandler"&gt;&lt;/action&gt; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;/transition&gt; &lt;/fork&gt; 这里怎么判断是执行"Tr_Cancel"还是执行"Tr_Request"呢? &nbsp;&nbsp; &lt;task-node name="TN_ChiefDecide"&gt; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;task name="Task_ChiefDecide"&gt; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;assignment class="com.myrequest.task.ChiefDecideAssignmentHandler"&gt;&lt;/assignment&gt; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;/task&gt; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;transition name="Tr_ChiefApprove" to="Deci_NeedBossDecide"&gt; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;action name="Ac_ChiefApprove" class="com.myrequest.action.ChiefApproveActionHandler"&gt;&lt;/action&gt; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;/transition&gt; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;transition name="Tr_ChiefNotApprove" to="Join_Request"&gt; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;action name="Ac_ChiefNotApprove" class="com.myrequest.action.ChiefNotApproveActionHandler"&gt;&lt;/action&gt; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;/transition&gt; &nbsp;&nbsp; &lt;/task-node&gt; 这里怎么判断是执行"Tr_ChiefApprove"还是执行"Tr_ChiefNotApprove"呢? 等待解答。谢谢了

  fork就相当于程序的分支,会分开去执行。当两个分支都执行完成后汇集到某以节点。
2 楼 darvsum 2009-01-04  
zpchen 你好!这段时间一直在研究你的这几篇文章,仍然有些地方不明白,请指导一下.下面是QingJiaWeb项目的工作流定义片段:

<decision name="Deci_IsChiefHere">
      <handler class="com.myrequest.decision.IsChiefHereDecisionHandler"/>
      <transition name="Tr_Chief" to="TN_ChiefDecide"></transition>
      <transition name="Tr_Boss" to="TN_BossDecide"></transition>
   </decision>
这段好明白,在IsChiefHereDecisionHandler中有判断知道应该执行"Tr_Chief",还是执行"Tr_Boss"。但在fork 和 task-node中并没有判断啊,那这么确定流程的转向呢?
<fork name="Fork_request">
     <transition name="Tr_Cancel"to="TN_RequesterCancel">
</transition>
      <transition name="Tr_Request" to="Deci_IsChiefHere">
         <action name="Ac_GetChiefState" class="com.myrequest.action.GetChiefStateActionHandler"></action>
      </transition>
</fork>
这里怎么判断是执行"Tr_Cancel"还是执行"Tr_Request"呢?

   <task-node name="TN_ChiefDecide">
      <task name="Task_ChiefDecide">
         <assignment class="com.myrequest.task.ChiefDecideAssignmentHandler"></assignment>
      </task>
      <transition name="Tr_ChiefApprove" to="Deci_NeedBossDecide">
         <action name="Ac_ChiefApprove" class="com.myrequest.action.ChiefApproveActionHandler"></action>
      </transition>
      <transition name="Tr_ChiefNotApprove" to="Join_Request">
         <action name="Ac_ChiefNotApprove" class="com.myrequest.action.ChiefNotApproveActionHandler"></action>
      </transition>
   </task-node>
这里怎么判断是执行"Tr_ChiefApprove"还是执行"Tr_ChiefNotApprove"呢?
等待解答。谢谢了
1 楼 crabboy 2008-11-27  
简单明了,jbpm的好文章啊。期待有更好的jbpm方面的文章啊

相关推荐

    JBPM采购申请系统——08_JBPM流程节点.7z

    JBPM采购申请系统——08_JBPM流程节点.7z JBPM采购申请系统——08_JBPM流程节点.7z JBPM采购申请系统——08_JBPM流程节点.7z JBPM采购申请系统——08_JBPM流程节点.7z JBPM采购申请系统——08_JBPM流程节点.7z JBPM...

    jbpm安装及使用方法

    很典型的用法是,当进入这个节点时(通过绑定一个action到node-enter event),发送一条消息到外部的系统,然后流程就处于等待状态。外部系统完成一些操作后返回一条消息,这个消息触发一个signal 到token,然后流程...

    不错的JBPM学习资料,从初级到高级

    基于jBPM的应用开发 ——jBPM实 ...各种类型节点的用法及应用场景 JBPM实现原理 系统架构和数据结构 基于JBPM的工作流应用平台开发 工作流应用平台介绍 设计和实现策略 现策略 基于jBPM的应用开发 高级特性

    jBPM4工作流应用开发指南.pdf

    jBPM4工作流应用开发指南 胡奇写的,十分赞!!

    jbpm介绍jbpm介绍jbpm介绍jbpm介绍jbpm介绍

    jbpm介绍jbpm介绍jbpm介绍jbpm介绍jbpm介绍jbpm介绍jbpm介绍jbpm介绍jbpm介绍jbpm介绍jbpm介绍jbpm介绍

    jbpm简介\jbpm简介

    \jbpm简介\jbpm简介\jbpm简介\jbpm简介\jbpm简介

    jbpm jbpm4.3.jar

    jbpm jbpm4.3.jar DDDDDDDD

    jbpm 数据库jbpm 数据库

    jbpm 数据库jbpm 数据库jbpm 数据库jbpm 数据库jbpm 数据库

    JBPM工作原理及表结构详解

    本文件从JBPM的原理、实现方法、实例等方面详细讲解了JBPM的原理,包括以下内容: 1、JBPM特色: 3 2、流程图的组成: 3 2.1流转 (TRANSITION) 3 2.2活动 (ACTIVITY) 3 3、所用到的表: 4 3.1资源库与运行时表结构:...

    jbpm4jbpm5

    jbpm应用开发指面(胡奇) jbpm4.3表结构和表字段说明 [jBPM开发指南].高杰.文字版 jBPM5_用户手册-中文版

    JBPM工作流应用开发文档

    JBPM工作流应用开发文档 如何安装jbmp,与jbpm简单入门

    jbpm 案例 jbpm jbpm

    jbpm使用案例,非常不错,大家都来看看吧。

    JBPM数据库表说明.doc

    JBPM数据库表说明 2 1 流程配置类数据库表: 2 1.1 JBPM_PROCESSDEFINITION:流程模版表 2 1.2 JBPM_NODE:流程节点表 2 1.3 JBPM_TRANSITION:流程迁移表 3 1.4 JBPM_ACTION:流程动作表 4 1.5 JBPM_EVENT:流程...

    jbpm3.2表说明

    jbpm3.2表说明 很详细 1.1 JBPM_PROCESSDEFINITION:流程模版表 关系表 外键存在表 外键名称 外键存在表字段 存在原因 可能...JBPM_LOG JBPM_LOG FK_LOG_NODE NODE_ 日志所属NODE,当日志类型为N(NodeLog)时使用

    jbpm的一个实例

    JBPM是一个扩展性很强的工作流系统,百分百用JAVA语言开发,持久层采用Hibernate实现,理论上说,只要Hibernate支持的数据库JBPM都支持。同时它还能被部署在任何一款JAVA应用服务器上 JBPM的工程文件,大家可以到...

    工作流jbpm应用的实例

    不错.自己学习的给大家分享.其实东西不难.只要先能写出一个流程.以后理解有帮助..

    jBPM4工作流应用开发指南.rar

    jBPM4工作流应用开发指南

    jbpm开发指南--jbpm全面介绍

    通过查看JBPM的表,我们知道要实现流程监控功能就是把JBPM当中的JBPM_PROCESSDEFINITION(已发布的流程表),JBPM_PROCESSINSTANCE(流程实例表),JBPM_TASKINSTANCE(流程产生的任务实例表)这三张表串联起来就可以...

Global site tag (gtag.js) - Google Analytics