定义

补偿中间抛出事件用于触发一个补偿,当执行到达补偿中间抛出事件时触发该流程已完成活动
的边界补偿事件(Compensate Boundary Interrputing Event),完成补偿操作后自动执行后继路线。

图形标记

补偿中间抛出事件显示为普通中间事件(内部有小圈的圆),内部是一个补偿小图标。补偿图
标是黑色的(有填充),表示抛出语义,如下图所示:

Flowable-中间事件-补偿中间抛出事件_flowable

XML内容

补偿中间抛出事件的 XML 内容是普通的中间抛出事件,包含一个 compensateEventDefinition
子元素:

<process id="intermediateThrowEventProcess">
     <intermediateThrowEvent id="intermediateCompensation" name="中间补偿事件">
        <compensateEventDefinition />
     </intermediateThrowEvent>
 </process>

使用示例

补偿中间事件主要用来触发补偿,它可以针对指定活动或包含补偿事件的作用域触发补偿,通
过执行与活动相关联的补偿处理器的 execution 来执行补偿。补偿遵循以下特点:

  1. 如果对某项活动进行补偿,则相关的补偿处理器执行的次数与活动成功完成的次数相同。
  2. 如果对当前作用域进行补偿,则对当前作用域内的所有活动进行补偿,包括并行分支上的活动。
  3. 补偿是分级触发的:如果要补偿的活动是子流程,则为子流程中包含的所有活动触发补偿。
    如果这个子流程有嵌套的活动,补偿会递归触发,但是补偿不会传播到比这个流程高的层级。如果
    补偿在子流程中触发,不会传播到该子流程作用域外的活动上。BPMN 规范规定,对于“同一级别
    的子流程”的活动,才触发补偿。
  4. Flowable 的补偿执行次序与流程执行顺序相反,这意味着最后完成的活动会最先执行补偿,依此类推。
  5. 中间补偿事件可以用来补偿已经完成的事务性子流程。
  6. 多实例活动抛出补偿时,只有当所有的实例都结束了相关的补偿处理器才会执行。这意味着多实例活动在被补偿前必须先被结束掉。

注意:

如果补偿被一个包含子流程的作用域触发,子流程还包含了关联补偿处理器的节点, 如果它已经成功完成了,补偿只会传播到子流程
如果子流程中的节点也完成了,并关联了补偿处理器,如果子流程包含的这些节点还没有完成,就不会执行补偿处理器

视频地址:
补偿中间抛出事件