流程引擎Camunda开发记录(九)外部任务系列

2022-04-29  本文已影响0人  _花

Camunda提供了外部任务,外部任务由外部应用去创建,引擎并不太会干预外部任务
ExternalTask 是ServiceTask的衍伸,但ServiceTask是非等待节点,流程执行实例经过ServiceTask节点时,直接经过并完成实例节点,而ExternalTask是等待节点,执行实例试行到此,会等待该任务的完成。

当你的流程实例流转到外部任务节点时,会向ACT_RU_EXT_TASK插入一条数据

1.获取外部任务的方法有

ExternalTaskQuery query = externalTaskService.createExternalTaskQuery();

2.外部服务进行抓取与锁定:

锁定

        long t = Long.parseLong(lockDuration);
        externalTaskService.lock(taskId, workerId, t);

解锁

        externalTaskService.unlock(externalTaskId);

外部服务可以定期来抓去自己关注的外部任任务并进行锁定

 @Test
    public void fetchAndLock() {
        int maxTasks = 5;
        String workerId = "peng1";
        boolean usePriority = true;
        int lockDuratio = 1000 * 60 * 10;
        List<LockedExternalTask> lockedExternalTaskList = externalTaskService
          .fetchAndLock(maxTasks, workerId, usePriority)
                .topic("topic1", lockDuratio)
                .execute();

        for (LockedExternalTask lockedExternalTask : lockedExternalTaskList) {
            System.out.println("#########");
            System.out.println(lockedExternalTask.getPriority());
            System.out.println(lockedExternalTask.getId());
            System.out.println(lockedExternalTask.getTopicName());
            System.out.println("#########");
        }
    }

fetchAndLock需要指定一次性抓取的外部任务的数量和执行人,外部服务也可以设置当前抓取的外部任务的主题

3.多主题多条件查询

前提是该任务上次锁定时间还没有过期
外部任务可以多次被不同的人锁定抓取,锁定时间和锁定人会随着每次抓取更新

4.完成外部任务

//成功
externalTaskService.complete(taskId, workderId, map);
//失败
externalTaskService.handleFailure(taskId, workderId, msg, retries, retryTimeOut);

完成外部任务后,外部任务会从ACT_RU_EXT_TASK表中删除

5.外部任务过期时间更新:

    @Test
    public void fetchAndLock2() {
        //锁定时间变更为:当前时间+5分钟
        Date date = new Date();
        date.setMinutes(date.getMinutes() - 5);
        ClockUtil.setCurrentTime(date);
        String externalTaskId = "2006";
        String workerId = "peng3";
        long lockDuration = 1000 * 60 * 10;
        externalTaskService.extendLock(externalTaskId, workerId, lockDuration);

        //或不用ClockUtil,直接        long lockDuration = 1000 * 60 * 5;
    }

6.重试次数优先级批更新及解锁

 @Test
    public void setRetries() {
        String externalTaskId = "2006";
        int retries = 4;
        externalTaskService.setRetries(externalTaskId, retries);
    }



    @Test
    public void setPriority() {
        String externalTaskId = "2006";
        int priority = 1000;
        externalTaskService.setPriority(externalTaskId, priority);
    }

上一篇 下一篇

猜你喜欢

热点阅读