这是我们(东方易维)工作流产品设计过程中采取的设计:
一、流程实例的状态
状态分为 5种:实例化、执行中、挂起、手工结束、正常结束。
状态的变迁如下图:
二、节点实例的状态
状态分为 5种:实例化、执行中、挂起、手工结束、正常结束。
状态的变迁如下图:
三、具体节点的状态
细分:
A、人工节点、等待节点
这两个节点被触发后存在一个执行等待的过程,所以可以被用户直接挂起和手工结束。人工节点的挂起意味着所有未完成工作项的挂起,同时相应时间服务的时间计算的挂起。手工结束会使流程跳过该节点(所有工作项手工结束),继续往后流转。
B、开始节点、结束节点、分支节点、自动节点
这些节点的特点在于被触发后立刻执行和流转,所以不会存在挂起和手工结束的状态。
C、并发节点、汇聚节点
并发节点和汇聚节点不存在挂起的状态,同时不能被用户直接手工结束,它们的状态受流程实例状态和相关节点实例状态的影响。
并发节点和汇聚节点的情况复杂一些,分模式讨论
图 1
1、同步汇聚(图 1)
根据情况触发节点 0、节点 1、节点 2中的一个或多个,汇聚节点等待所有实际触发的节点完成后再执行流转。中间汇聚节点只会产生一个实例。
1.1、正常流转时的处理策略
当汇聚节点未被触发时(即节点 0、节点 1、节点 2都未执行结束),并发节点处于执行状态,一旦汇聚节点被触发(即节点 0、节点 1、节点 2有一个执行结束),并发节点正常结束并且汇聚节点处于执行状态,所有并发出的节点实例执行结束后,汇聚节点正常结束,流程继续流转。
1.2、用户挂起、手工结束相关节点的处理策略
1.2.1、汇聚节点未激活时
节点 0、节点 1、节点 2的挂起和恢复执行不会影响并发节点的状态(依旧处于执行状态);节点 0、节点 1、节点 2的任一手工结束都会触发汇聚节点,使并发节点正常结束,如果所有并发的节点实例都结束(包括手工结束和正常结束),汇聚节点正常结束,触发流程流转。
1.2.2、汇聚节点已激活时
节点 0、节点 1、节点 2的挂起和恢复执行不会影响汇聚节点的状态(依旧处于执行状态);节点 0、节点 1、节点 2的手工结束会影响汇聚节点的状态,每个节点实例的手工结束会引起汇聚节点的判断,如果所有并发的节点实例(包括正常结束和手工结束)都结束,汇聚节点正常结束,触发流程流转。
1.3、用户挂起、手工结束流程的处理策略
1.3.1、汇聚节点未激活时
流程的挂起和恢复执行不会影响并发节点的状态(依旧处于执行状态),节点 0、节点 1、节点 2会被全部挂起或恢复;流程的手工结束会引起所有节点的手工结束。
1.3.2、汇聚节点已激活时
流程的挂起和恢复执行不会影响汇聚节点的状态(依旧处于执行状态),节点 0、节点 1、节点 2未执行结束的实例会被全部挂起或恢复;流程的手工结束会引起所有节点的手工结束。
2、nOutOfM汇聚(图 1)
根据情况触发节点 0、节点 1、节点 2中的一个或多个,汇聚节点等待 N个实际触发的节点完成后即执行流转( N>0且 N<M, M为实际触发的节点个数),在 N<=0和 N>=M的情况下即为同步汇聚。中间汇聚节点只会产生一个实例。
2.1、正常流转时的处理策略
当汇聚节点未被触发时(即节点 0、节点 1、节点 2都未执行结束),并发节点处于执行状态,一旦汇聚节点被触发(即节点 0、节点 1、节点 2有一个执行结束),并发节点正常结束并且汇聚节点处于执行状态, N个并发出的节点实例执行结束后,汇聚节点正常结束,流程继续流转, M-N的节点实例被手工结束。
2.2、用户挂起、手工结束相关节点的处理策略
2.2.1、汇聚节点未激活时
节点 0、节点 1、节点 2的挂起和恢复执行不会影响并发节点的状态(依旧处于执行状态);节点 0、节点 1、节点 2的任一手工结束都会触发汇聚节点,使并发节点正常结束,如果 N个并发的节点实例都手工结束,并发节点正常结束,触发汇聚节点,汇聚节点正常结束,触发流程流转, M-N的节点实例被手工结束。
2.2.2、汇聚节点已激活时
节点 0、节点 1、节点 2的挂起和恢复执行不会影响汇聚节点的状态(依旧处于执行状态);节点 0、节点 1、节点 2的手工结束会影响汇聚节点的状态,每个节点实例的手工结束会引起汇聚节点的判断,如果 N个并发的节点实例(包括正常结束和手工结束)都结束,汇聚节点正常结束,触发流程流转, M-N的节点实例被手工结束。
2.3、用户挂起、手工结束流程的处理策略
2.3.1、汇聚节点未激活时
流程的挂起和恢复执行不会影响并发节点的状态(依旧处于执行状态),节点 0、节点 1、节点 2会被全部挂起或恢复;流程的手工结束会引起所有节点的手工结束。
2.3.2、汇聚节点已激活时
流程的挂起和恢复执行不会影响汇聚节点的状态(依旧处于执行状态),节点 0、节点 1、节点 2未执行结束的实例会被全部挂起或恢复;流程的手工结束会引起所有节点的手工结束。
3、辨别汇聚(图 1)
是 nOutOfM汇聚的特例, N=1
4、多实例汇聚(图 2)
图 2
根据情况触发节点 0、节点 1中的一个或多个,节点 0和节点 1任意一个执行结束后都会触发汇聚节点产生一个新的实例,汇聚节点实例紧接着触发节点 2,节点 2也会产生多个实例。
4.1、正常流转时的处理策略
当汇聚节点未被触发时(即节点 0、节点 1都未执行结束),并发节点处于执行状态,一旦汇聚节点被触发(即节点 0、节点 1有一个执行结束),汇聚节点会紧接着触发节点 2,汇聚节点正常结束。所有并发出的节点实例执行结束后,并发节点正常结束。
4.2、用户挂起、手工结束相关节点的处理策略
节点 0、节点 1的挂起和恢复执行不会影响并发节点的状态(依旧处于执行状态);节点 0、节点 1的手工结束会影响并发节点和汇聚节点的状态,每个节点实例的手工结束会引起汇聚节点产生新的实例并触发节点 2,同时会引起并发节点的判断,如果所有并发的节点实例都手工结束,并发节点正常结束。
4.3、用户挂起、手工结束流程的处理策略
流程的挂起和恢复执行不会影响并发节点的状态(依旧处于执行状态),节点 0、节点 1、节点 2会被全部挂起或恢复;流程的手工结束会引起所有未结束节点的手工结束。
5、隐式结束,没有汇聚节点与并发节点对应(图 3)
图 3
所有节点结束时(正常结束或手工结束),并发节点正常结束。流程的手工结束会引起所有未结束节点的手工结束。
四、流程实例状态变化对节点实例状态造成的影响
1、流程实例的挂起
A类节点挂起, B、 C类节点不受影响。同时在流程实例恢复执行之前, A类节点不允许用户直接恢复执行。
2、流程实例的手工结束
所有节点全部手工结束。
五、节点实例状态变化对流程实例状态造成的影响
隐式结束的情况下,节点的手工结束或正常结束都会触发流程的判断,如果所有的节点都已结束则流程结束。