`
kayzhan
  • 浏览: 112369 次
  • 性别: Icon_minigender_2
  • 来自: 上海
社区版块
存档分类
最新评论

jBPM4.0的用户指南(五-3)

    博客分类:
  • jbpm
阅读更多
续第5章JPDL

5.2.4. concurrency并发

使用fork和join活动,可以模拟流向(executions)的汇合。

例子:
流程处理的并发例子

图 5.6. 流程处理的并发例子

<process name="ConcurrencyGraphBased" xmlns="http://jbpm.org/4/jpdl">
    <start>
        <transition to="fork" />
    </start>

    <fork name="fork">
        <transition to="send invoice" />
        <transition to="load truck" />
        <transition to="print shipping documents" />
    </fork>

    <state name="send invoice">
        <transition to="final join" />
    </state>

    <state name="load truck">
        <transition to="shipping join" />
    </state>

    <state name="print shipping documents">
        <transition to="shipping join" />
    </state>

    <join name="shipping join">
        <transition to="drive truck to destiation" />
    </join>

    <state name="drive truck to destiation">
        <transition to="final join" />
    </state>

    <join name="final join">
        <transition to="end" />
    </join>

    <end name="end" />

</process>
           

5.2.5. end结束

结束流向
5.2.5.1. end process instance结束流程处理实例


默认情况下,结束活动会终结已完成流程处理实例。因此在流程处理实例中,仍然在活动的多个并发(concurrent)流向(concurrent)也会结束。
结束活动

图 5.7. 结束活动

<process name="EndProcessInstance" xmlns="http://jbpm.org/4/jpdl">
    <start>
        <transition to="end" />
    </start>

    <end name="end" />

</process>
               

新的流程处理实例一创建便会直接结束。
5.2.5.2. end execution结束流向

只有流向到达结束(end)活动时会结束流程处理实例,并且其他并发流向会放弃活动。我们可以设置属性ends="execution"来达到这种状况。

表 5.8. end execution属性
属性 类型 默认值 是否必须 描述
ends {processinstance|execution} processinstance optional可选 流向路径到达end活动整个流程处理实例就会结束,

5.2.5.3. end multiple多个结束

一个流程处理可以有多个end events,这样就很容易显示出流程处理实例的不同结果。示例:
多个end events

图 5.8. 多个end events

<prccess name="EndMultiple" xmlns="http://jbpm.org/4/jpdl">
    <start>
        <transition to="get return code" />
    </start>

    <state name="get return code">
        <transition name="200" to="ok" />
        <transition name="400" to="bad request" />
        <transition name="500" to="internal server error" />
    </state>

    <end name="ok" />

    <end name="bad request" />

    <end name="internal server error" />

</process>
               

如果你启动一个流向并使用下面的代码将它执行到get return code等待状态,流向便会以bad request的end 活动(event)结束

Execution execution = executionService.startProcessInstanceByKey("EndMultiple");
String executionId = execution.getId();
execution = executionService.signalExecutionById(executionId, "400");
               

同样地,使用值为200或者500就会让流向(execution)分别以ok或者internal server error的end events结束。
5.2.5.4. end State结束状态


流向(execution)可以以不同的状态结束。可以用其他的方式列出流程处理实例的结果。可以用end event的状态属性或者end-cancel和end-error表示。

表 5.9. end execution 属性

属性 类型 默认值 是否必须 描述
state String 可选 状态分配给流向

不同的结束状态

图 5.9. 不同的结束状态

<process name="EndState" xmlns="http://jbpm.org/4/jpdl">
    <start>
        <transition to="get return code" />
    </start>

    <state name="get return code">
        <transition name="200" to="ok" />
        <transition name="400" to="bad request" />
        <transition name="500" to="internal server error" />
    </state>

    <end state="comleted" />
    <end-cancel name="bad request" />
    <end-error name="internal server error" />

</process>
               

这时,如果我们启动一个流向并使用下面的代码将流向执行到get return code等待状态,流向会以取消状态(cancel state)结束。

Execution execution = executionService.startProcessInstanceByKey("EndState");
String executionId = execution.getId();
execution = executionService.signalExecutionById(executionId, "400");
               

和上面一样,使用值为200或500会让流向分别以comleted或者error states结束。
分享到:
评论
2 楼 kayzhan 2009-09-27  
呵呵,这就分支聚合啊,它是自动的,不知道你想如何处理,需求是什么 ?
1 楼 diffuser 2009-09-27  
<?xml version="1.0" encoding="UTF-8"?>

<process name="test_fork" xmlns="http://jbpm.org/4.0/jpdl">
<start g="105,85,48,48" name="start1">
<transition name="to task1" to="task1" g="-53,-17" />
</start>
<task g="290,95,92,52" name="task1">
<assignment-handler class="org.jbpm.df.AssignTask" />
<transition name="to fork1" to="fork1" g="-53,-17" />
</task>
<task name="task2" g="158,248,92,52">
<assignment-handler class="org.jbpm.df.AssignTask" />
<transition name="to join1" to="join1" g="-53,-17" />
</task>
<task name="task3" g="165,348,92,52">
<assignment-handler class="org.jbpm.df.AssignTask" />
<transition name="to join1" to="join1" g="-53,-17" />
</task>
<fork name="fork1" g="46,287,48,48">
<transition name="to task2" to="task2" g="-53,-17" />
<transition name="to task3" to="task3" g="-53,-17" />
</fork>
<join name="join1" g="335,300,48,48">
<transition name="to task4" to="task4" g="-53,-17" />
</join>
<task name="task4" g="465,295,92,52">
<assignment-handler class="org.jbpm.df.AssignTask" />
<transition name="to end1" to="end1" g="-47,-17" />
</task>
<end name="end1" g="447,409,48,48" />
</process>


我这里是一个task结束后,进入fork节点,然后分成两个task,再进入join,请问该如何处理?

相关推荐

Global site tag (gtag.js) - Google Analytics