jBPM4.0的用户指南(5-3)
jBPM4.0的用户指南(五-3)
续第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结束。
续第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结束。
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,请问该如何处理?
<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,请问该如何处理?
2 楼
kayzhan
2009-09-27
呵呵,这就分支聚合啊,它是自动的,不知道你想如何处理,需求是什么 ?