Flowable源码注释(三十二)任务超时作业

本文深入探讨Flowable的源码,重点关注TimerExecuteNestedActivityJobHandler,这是一个处理任务超时的作业处理器。通过分析Flowable在6.7.2版本的源码注释,了解任务超时的内部工作机制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Flowable源码地址:https://github.com/flowable/flowable-engine

Flowable-6.7.2 源码注释地址:https://github.com/solojin/flowable-6.7.2-annotated

包路径:org.activiti.engine.impl.jobexecutor

TimerExecuteNestedActivityJobHandler 定时器执行嵌套活动作业处理器,即任务超时作业

package org.activiti.engine.impl.jobexecutor;

import org.activiti.engine.ActivitiException;
import org.activiti.engine.delegate.event.impl.ActivitiEventBuilder;
import org.activiti.engine.impl.bpmn.behavior.BoundaryEventActivityBehavior;
import org.activiti.engine.impl.interceptor.CommandContext;
import org.activiti.engine.impl.persistence.entity.ExecutionEntity;
import org.activiti.engine.impl.pvm.process.ActivityImpl;
import org.flowable.common.engine.api.delegate.event.FlowableEngineEventType;
import org.flowable.common.engine.impl.interceptor.EngineConfigurationConstants;
import org.flowable.engine.impl.delegate.ActivityBehavior;
import org.flowable.job.api.Job;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * 定时器执行嵌套活动作业处理器
 * 即任务超时作业。在实际项目中,可以为任务节点绑定一个定时边界事件,如果任务节点在指定时间之内没有结束,则流程引擎实例会按照边界事件的方向执行
 *
 * @author Tom Baeyens
 * @author Joram Barrez
 */
public class TimerExecuteNestedActivityJobHandler extends TimerEventHandler implements JobHandler {

    private static final Logger LOGGER = LoggerFactory.getLogger(TimerExecuteNestedActivityJobHandler.class);

    // 类型:定时器-转换
    public static final String TYPE = "timer-transition";
    public static final String PROPERTYNAME_TIMER_ACTIVITY_ID = "activityId";
    public static final String PROPERTYNAME_END_DATE_EXPRESSION = "timerEndDate";

    @Override
    public String getType() {
        return TYPE;
    }

    @Override
    public void execute(Job job, String configuration, ExecutionEntity execution, CommandContext commandContext) {

        String nestedActivityId = TimerEventHandler.getActivityIdFromConfiguration(configuration);

        ActivityImpl borderEventActivity = execution.getProcessDefinition().findActivity(nestedActivityId);

        if (borderEventActivity == null) {
            // 触发定时器时出错:未找到边界事件活动“+nestedActivityId+”
            throw new ActivitiException("Error while firing timer: border event activity " + nestedActivityId + " not found");
        }

        try {
            if (commandContext.getEventDispatcher().isEnabled()) {
                commandContext.getEventDispatcher().dispatchEvent(
                        ActivitiEventBuilder.createEntityEvent(FlowableEngineEventType.TIMER_FIRED, job),
                        EngineConfigurationConstants.KEY_PROCESS_ENGINE_CONFIG);
                dispatchActivityTimeoutIfNeeded(job, execution, commandContext);
            }

            borderEventActivity
                    .getActivityBehavior()
                    .execute(execution);
        } catch (RuntimeException e) {
            // 定时器执行期间出现异常
            LOGGER.error("exception during timer execution", e);
            throw e;

        } catch (Exception e) {
            // 定时器执行期间出现异常
            LOGGER.error("exception during timer execution", e);
            // 定时器执行期间出现异常
            throw new ActivitiException("exception during timer execution: " + e.getMessage(), e);
        }
    }

    // 条件调度超时活动
    protected void dispatchActivityTimeoutIfNeeded(Job timerEntity, ExecutionEntity execution, CommandContext commandContext) {

        String nestedActivityId = TimerEventHandler.getActivityIdFromConfiguration(timerEntity.getJobHandlerConfiguration());

        ActivityImpl boundaryEventActivity = execution.getProcessDefinition().findActivity(nestedActivityId);
        ActivityBehavior boundaryActivityBehavior = boundaryEventActivity.getActivityBehavior();
        if (boundaryActivityBehavior instanceof BoundaryEventActivityBehavior) {
            BoundaryEventActivityBehavior boundaryEventActivityBehavior = (BoundaryEventActivityBehavior) boundaryActivityBehavior;
            if (boundaryEventActivityBehavior.isInterrupting()) {
                dispatchExecutionTimeOut(timerEntity, execution, commandContext);
            }
        }
    }

    // 调度超时执行
    protected void dispatchExecutionTimeOut(Job job, ExecutionEntity execution, CommandContext commandContext) {
        // 子流程
        for (ExecutionEntity subExecution : execution.getExecutions()) {
            dispatchExecutionTimeOut(job, subExecution, commandContext);
        }

        // 调用活动
        ExecutionEntity subProcessInstance = commandContext.getExecutionEntityManager().findSubProcessInstanceBySuperExecutionId(execution.getId());
        if (subProcessInstance != null) {
            dispatchExecutionTimeOut(job, subProcessInstance, commandContext);
        }

        // 带有定时器边界事件的活动
        ActivityImpl activity = execution.getActivity();
        if (activity != null && activity.getActivityBehavior() != null) {
            dispatchActivityTimeOut(job, activity, execution, commandContext);
        }
    }

    // 调度超时活动
    protected void dispatchActivityTimeOut(Job job, ActivityImpl activity, ExecutionEntity execution, CommandContext commandContext) {
        commandContext.getEventDispatcher().dispatchEvent(
                ActivitiEventBuilder.createActivityCancelledEvent(activity.getId(),
                        (String) activity.getProperties().get("name"),
                        execution.getId(),
                        execution.getProcessInstanceId(), execution.getProcessDefinitionId(),
                        (String) activity.getProperties().get("type"),
                        activity.getActivityBehavior().getClass().getCanonicalName(),
                        job), EngineConfigurationConstants.KEY_PROCESS_ENGINE_CONFIG);
    }

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值