flowable工作流
Survive by day and develop by night.
talk for import biz , show your perfect code,full busy,skip hardness,make a better result,wait for change,challenge Survive.
happy for hardess to solve denpendies.
目录

概述
工作流,是把业务之间的各个步骤以及规则进行抽象和概括性的描述。使用特定的语言为业务流程建模,让其运行在计算机上,并让计算机进行计算和推动。
需求:
工作流是复杂版本的状态机。
上图为工作流退化为基础状态机的例子,小明的状态非常简单,站立->走路->跑步->走路->站立,无限循环,如果让我们实现小明的状态切换,那么我们只需要用一个字段来记录小明当前的状态就好了。
设计思路
实现思路分析
1.复杂的状态的或者状态的维度增加的状的条件极为复杂
而对于复杂的状态或者状态维度增加且状态流转的条件极为复杂,可能单纯用字段记录状态的实现方式就会不那么理想。
2.工作流
工作流解决的痛点在于,解除业务宏观流程和微观逻辑的耦合,让熟悉宏观业务流程的人去制定整套流转逻辑,而让专业的人只需要关心他们应当关心的流程节点,就好比大家要一起修建一座超级体育场,路人甲只需要关心他身边的这一堆砖是怎么堆砌而非整座建筑。
3.BPMN2.0协议
对于业务建模,我们需要一种通用的语言来描绘,这样在沟通上和实现上会降低难度,就像中文、英文一样,BPMN2.0便是一种国际通用的建模语言,他能让自然人轻松阅读,更能被计算机所解析。
4.协议的元素
协议中元素的主要分类为,事件-任务-连线-网关。
一个流程必须包含一个事件(如:开始事件)和至少一个结束(事件)。其中网关的作用是流程流转逻辑的控制。任务则分很多类型,他们各司其职,所有节点均由连线联系起来。
5.互斥网关
又称排他网关,他有且仅有一个有效出口,可以理解为if…else if… else if

本文介绍了工作流的概念及其复杂性,强调了解耦合业务流程的重要性。Flowable是一个基于BPMN2.0协议的Java实现,提供了包括人工任务、服务任务、互斥网关和包容性网关在内的多种任务类型。文章讨论了不同网关的逻辑,并探讨了Flowable的异步执行器和数据处理策略,以及如何将业务逻辑转化为流程图。此外,还提到了如何通过API管理和操作流程实例,以及用户角色的分类逻辑。
最低0.47元/天 解锁文章
4778





