Camunda流程引擎笔记(四):Send Task,Receive Task

流程引擎中 Send TaskService Task 拥有相同的行为,都是通过回调Java代码完成相应逻辑。通常 Send TaskReceive Task 配合使用。

一、Send Task

绘制一个 Send Task 流程,配置过程和 Service Task 一样。

Camunda流程引擎笔记(四):Send Task,Receive Task

二、Receive Task

A Receive Task is a simple task that waits for the arrival of a certain message. When the process execution arrives at a Receive Task, the process state is committed to the persistence storage. This means that the process will stay in this wait state until a specific message is received by the engine, which triggers continuation of the process beyond the Receive Task.

翻译:接收任务是一个简单的任务,它等待特定消息的到来。当流程执行到达接收任务时,流程状态被提交到持久性存储。这意味着流程将保持这种等待状态,直到引擎接收到特定的消息,这将触发Receive任务之外的流程继续。

简单来说就是流程到达 Receive Task 节点后将持久化这个状态直到接收到一个特定的消息,才会继续往下走。

绘制一个 Receive Task 流程。

Camunda流程引擎笔记(四):Send Task,Receive Task

三、测试

  • 编写Java回调类。

    这里的 .createMessageCorrelation("message") 中配置了上面流程图中的 Message Name 填写字符串。

    .processInstanceBusinessKey("messageBusinessKey") 中填写了一个特定的业务key,方便找到特定的 Receive Task 流程。

    public class SendTaskDelegate implements JavaDelegate {
        @Override
        public void execute(DelegateExecution execution) throws Exception {
            execution.getProcessEngineServices()
                    .getRuntimeService()
                    .createMessageCorrelation("message")
                    .processInstanceBusinessKey("messageBusinessKey")
                    .correlate();
        }
    }
  • 启动流程。

    首先启动 Send Task 流程可以看到以下错误:

    Camunda流程引擎笔记(四):Send Task,Receive Task

    很明显,这是提示我们需要首先启动一个 Receive Task 流程实例以接收 Send Task 流程实例发送的消息。

    启动 Send Task 流程实例。

    Camunda流程引擎笔记(四):Send Task,Receive Task

    这里 Business Key 填写了上面代码中配置的 messageBusinessKey

    访问 http://localhost:8080/app/cockpit/default/#/dashboard ,可以看到有一个活动中的流程:

    Camunda流程引擎笔记(四):Send Task,Receive Task

    点击 Running Process Instances

    Camunda流程引擎笔记(四):Send Task,Receive Task

    这里显示 Receive Task 流程停止在了 receive message 节点上。

    接下来启动一个 Send Task 流程实例:

    Camunda流程引擎笔记(四):Send Task,Receive Task

    再次访问 http://localhost:8080/app/cockpit/default/#/dashboard ,可以看到已经没有执行中的流程了:

    Camunda流程引擎笔记(四):Send Task,Receive Task

    说明 Receive Task 流程已经接受到了 Send Task 流程发送的 message 消息,所以流程继续执行直到结束。

原文 

https://segmentfault.com/a/1190000022128311

本站部分文章源于互联网,本着传播知识、有益学习和研究的目的进行的转载,为网友免费提供。如有著作权人或出版方提出异议,本站将立即删除。如果您对文章转载有任何疑问请告之我们,以便我们及时纠正。

PS:推荐一个微信公众号: askHarries 或者qq群:474807195,里面会分享一些资深架构师录制的视频录像:有Spring,MyBatis,Netty源码分析,高并发、高性能、分布式、微服务架构的原理,JVM性能优化这些成为架构师必备的知识体系。还能领取免费的学习资源,目前受益良多

转载请注明原文出处:Harries Blog™ » Camunda流程引擎笔记(四):Send Task,Receive Task

赞 (0)
分享到:更多 ()

评论 0

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址