前言:工作流流程过程中,除了正常的人工审批类型的节点外,事件类型的节点处理也尤为重要。比如比较常见的事件类型的节点有:Timer/Message/Signal等。本文重点阐述消息类型的节点处理,以及实现消息驱动流程过程中对消息队列(RabbitMQ)的集成使用方式。

1. 节点间消息传递

1.1 MessageThrow

消息抛出节点,当执行到这个节点时,特定消息主题的消息记录将会添加到消息队列,然后等待被订阅的消息消费者来激活消息处理服务。

1.2 MessageCatch

消息接收节点,消息接收节点上定义了消息主题,并且在消息队列中订阅了该主题。当有特定主题的消息被发布时候,消息消费者会捕获到消息主题,同时消息处理服务中,将会定位到流程的该节点位置,然后通过流程服务来判定下一步的流转流转。

1.3 单一流程内的节点消息传递

该流程只进行消息的发布或者接收,而消息的另外一方则可能是业务系统。两者之间的关联是靠消息主题来识别。如下图所示:

1.4 跨流程间的节点消息传递

通常可以用泳道流程来表示跨流程间的消息通知。泳道流程中,有多个流程,其中一个是泳道主流程,其它的则为泳道附属流程。将会在下面的章节中具体描述。

2. 跨流程消息传递

2.1 泳道流程

泳道流程中,使用多个泳道来区分不同的流程,流程之间可以通过消息来传递信息,如下图所示:

2.2 消息节点类型

消息节点在流程中的位置主要有:开始节点(Start)、中间节点(Internmediate)和结束节点(End)

3. 消息队列(RabbitMQ)集成使用

3.1 消息队列介绍

RabbitMQ是实现了高级消息队列协议(AMQP)的开源消息代理软件(亦称面向消息的中间件)。RabbitMQ服务器是用Erlang语言编写的,而群集和故障转移是构建在开放电信平台框架上的。所有主要的编程语言均有与代理接口通讯的客户端库。

来源:https://baike.baidu.com/item/rabbitmq/9372144?fr=aladdin

3.2 消息队列集成引擎

Slickflow引擎集成RabbitMQ消息队列,其特点是:已经经过大量用户案例检验,证明性能能够满足日常业务需求,同时文档丰富,便于开发人员学习上手。

4. 泳道流程消息队列集成案例

下图是泳道流程的具体示例,包含了一个主流程,和一个泳道附属流程,两个流程间的触发处理,是靠消息来传递。

4.1 流程协作说明

    1) 泳道附属流程的启动

泳道附属流程的开始节点(StartCatch)是一个消息接收节点,其接收内容来自主流程的中间消息节点(IntermediateThrow)。当订单主流程的“同步订单”节点完成后,将会发布消息,此时,生产附属流程因为订阅了该消息主题,所以根据开始节点的类型为消息触发类型,生产附属流程将会被启动,生成新的流程实例。

    2) 中间消息节点接收消息

流程运行到到中间节点位置后,需要等待特殊主体的消息记录后,然后才能继续流转。常见的场景:比如电子商务系统接入第三方支付系统时,当商城客户下单支付后,从第三方回传支付成功的消息后,当前的订购流程财主继续向下流转。这种消息等待接收的处理,就可以使用消息队列来完成。

在泳道流程中,当"生产计划"流程完成后,将会发布消息给主流程,泳道主流程接收到消息后,可以继续处理当前的节点,并且向下进行流程流转到"客户反馈"节点。

4.2 消息驱动过程说明

    1) 消息发布代码示例

        /// <summary>
/// 消息发布
/// </summary>
/// <param name="topic">主题</param>
/// <param name="line">内容</param>
public void Publish(string topic, string line)
{
var channel = MQClientFactory.CreatePublishChannel();
channel.QueueDeclare(queue: topic,
durable: false,
exclusive: false,
autoDelete: false,
arguments: null); var body = Encoding.UTF8.GetBytes(line);
channel.BasicPublish(exchange: "",
routingKey: topic,
basicProperties: null,
body: body);
}

  

    2) 消息订阅代码示例

        /// <summary>
/// 消息订阅
/// </summary>
/// <param name="topic">主题</param>
/// <returns></returns>
public void Subscribe(string topic)
{
var channel = MQClientFactory.CreateRecieveChannel();
channel.QueueDeclare(queue: topic,
durable: false,
exclusive: false,
autoDelete: false,
arguments: null); var consumer = new EventingBasicConsumer(channel);
consumer.Received += (model, ea) =>
{
var body = ea.Body;
var line = Encoding.UTF8.GetString(body);
var msgMediator = new MessageMediator();
msgMediator.InvokeFromMessage(ConsumeMessageFunction, topic, line);
};
channel.BasicConsume(queue: topic,
autoAck: true,
consumer: consumer);
}

5. 消息队列数据监控

RabbitMQ带有后台面板监控,可以看到消息队列中的数据情况,可以帮助开发人员调试消息处理程序的正常工作。

6. 总结

流程引擎集成消息队列RabbitMQ的方式,可以保障业务系统跟流程关联系统集成关联的可靠性。存在消息队列中的消息主题,可以被消息订阅方在后期处理,使得系统的部署更加灵活,降低了系统之间的耦合性。其次,跨流程直接的消息通讯比较常见,通过集成消息队列来存储消息和分发消息,可以使得业务系统处理的能力加强。从单一流程的流转过度到多流程直接的集体协作模式。

.NET 开源工作流: Slickflow流程引擎高级开发(七)--消息队列(RabbitMQ)的集成使用的更多相关文章

  1. .NET 开源工作流: Slickflow流程引擎高级开发(十) -- BpmnJS流程设计器集成

    前言: 在Slickflow产品开发过程中,前端流程设计器经历了几个不同的版本(jsPlumb, mxGraph等),目的是为了在设计流程时的用户体验更加良好,得到客户的好评和认可.BpmnJS流程设 ...

  2. .NET 开源工作流: Slickflow流程引擎高级开发(八) -- 审批网关(ApprovalOrSplit)模式的应用

    前言:业务流程流转过程中,审批类型的节点是比较常见的,在审批操作中,常见的操作就是就是主管人员对待办事项进行同意或者拒绝.所以网关处理节点,就是需要对这两种审批结果进行预备处理,审批网关是在或分支(O ...

  3. .NET 开源工作流: Slickflow流程引擎高级开发(九) -- 条件事件模式解释及应用

    前言:在流程流转过程中,有时候需要条件模式的支持,这样可以使得流程流转更加灵活多变.比如在业务变量满足一定的条件时,可以启动特定配置的流程(或者位于主流程内部的子流程).本文主要描述条件启动和条件中间 ...

  4. Slickflow.NET 开源工作流引擎高级开发(三) -- 并行分支容器与会签工作流模式的组合

    前言:  流程引擎的核心功能是负责解析流程定义XML和流转,业务环节的不断积累,让人们不断总结和抽象出一些模式,这些模式统称为工作流模式(Workflow Pattern).本文的重点就是介绍一种常见 ...

  5. asp.net开源流程引擎API开发调用接口大全-工作流引擎设计

    关键词: 工作流引擎 BPM系统 接口调用 工作流快速开发平台  工作流流设计  业务流程管理   asp.net 开源工作流 一.程序调用开发接口二.   接口说明 所谓的驰骋工作流引擎的接口,在B ...

  6. Slickflow.NET 开源工作流引擎高级开发(二) -- 流程快速测试增值服务工具介绍

    前言:流程是由若干个任务节点组成,流转过程就是从一个节点转移到下一个节点,通常需要不断切换用户身份来完成流程的测试,这样使得测试效率比较低下,本文从实战出发,介绍常见的两种快速测试方法,用于提升流程测 ...

  7. Slickflow.NET 开源工作流引擎高级开发(一) -- 流程外部事件的调用和变量存储实现

    前言:流程实现基本流转功能外,通常也需要调用外部事件,用于和业务系统的交互,同时存储一些流程变量,用于追踪和记录业务数据变化对流程流转的影响. 1. 流程事件 流程执行过程中,伴随各种事件的发生,而且 ...

  8. Slickflow.NET 开源工作流引擎高级开发(六) -- WebTest 引擎接口模拟测试工具集

    前言:引擎组件的接口测试不光是程序测试人员使用,而且也是产品负责人员需要用到的功能,因为在每一步流转过程中,就会完整模拟实际用户发生的场景,也就容易排查具体是程序问题还是业务问题,从而快速定位问题,及 ...

  9. java工作流系统-流程引擎执行自定义URL

    关键词:工作流快速开发平台  工作流流设计  业务流程管理   asp.net 开源工作流    bpm工作流系统  java工作流主流框架  自定义工作流引擎 概要介绍: 用户在表达自己的业务逻辑时 ...

随机推荐

  1. Java实现 蓝桥杯 算法提高 歌唱比赛(暴力)

    试题 算法提高 歌唱比赛 问题描述 X市正在进行歌唱比赛,请你写一个程序计算得分. 每名选手从1到N编号,每名选手的综合成绩由以下几个部分组成: 1.歌唱得分占70% 2.才艺展示得分占20% 3.观 ...

  2. Java实现 LeetCode 730 统计不同回文子字符串(动态规划)

    730. 统计不同回文子字符串 给定一个字符串 S,找出 S 中不同的非空回文子序列个数,并返回该数字与 10^9 + 7 的模. 通过从 S 中删除 0 个或多个字符来获得子字符序列. 如果一个字符 ...

  3. (Java实现) 图的m着色问题

    图的m着色问题 [问题描述] 给定无向连通图G和m种不同的颜色.用这些颜色为图G的各顶点着色,每个顶点着一种颜色.如果有一种着色法使G中每条边的2个顶点着不同颜色,则称这个图是m可着色的.图的m着色问 ...

  4. java实现括号的匹配

    括号的匹配 下面的代码用于判断一个串中的括号是否匹配 所谓匹配是指不同类型的括号必须左右呼应,可以相互包含,但不能交叉 例如: -(-[-]-)- 是允许的 -(-[-)-]- 是禁止的 对于 mai ...

  5. Java实现 蓝桥杯 历届试题 错误票据

    问题描述 某涉密单位下发了某种票据,并要在年终全部收回. 每张票据有唯一的ID号.全年所有票据的ID号是连续的,但ID的开始数码是随机选定的. 因为工作人员疏忽,在录入ID号的时候发生了一处错误,造成 ...

  6. 支持MMDVM的DMR手台

    只要是数字机,都支持,但是,有便宜又好用的吗?当然有,店主做那么久肯定知道哪些机好用 1.MD760(UV双段) 刷固件支持#切换不同的TG,可以手动改机子的DMR ID,可以下载联系人,可以升级!关 ...

  7. C++拷贝构造函数被调用的时机

    拷贝构造函数调用的几种情况: 当用类的一个对象去初始化该类的另一个对象(或引用)时系统自动调用拷贝构造函数实现拷贝赋值. 若函数的形参为类对象,调用函数时,实参赋值给形参,系统自动调用拷贝构造函数.( ...

  8. 举一个有趣的例子,让你轻松搞懂JVM内存管理

    目录 前言 例子 源码 输出 图解 深入分析 学以致用 写在最后 前言 在JAVA虚拟机内存管理中,堆.栈.方法区.常量池等概念经常被提到,对理论知识的理解也常常停留在字面意思上,比如说堆内存中存放对 ...

  9. SpringCloud+Ehcache

    1.pom文件引入 <!-- https://mvnrepository.com/artifact/org.ehcache/ehcache --><dependency>< ...

  10. PBFT共识算法

    拜占庭将军问题 我们已知的共识算法,Paxos.Raft解决的都是非拜占庭问题,也就是可以容忍节点故障,消息丢失.延时.乱序等,但节点不能有恶意节点.但如何在有恶意节点存在的情况下达成共识呢?BFT共 ...