runflow流程引擎框架

联合创作 · 2023-09-30 06:34

runflow是一个基于逻辑流转的无状态轻量级流程引擎。 runflow支持BPMN规范,能够把复杂的业务逻辑可视化。开发人员可以通过流程编辑器设计自己的业务流程,为业务设计人员与开发工程师架起一座桥梁。

2. 特性

  • 规则轻量:只要稍微了解bmpn规范的人员就快速上手。三分钟入门,一看既懂。
  • 丰富业务场景:支持排他网关,并行网关。可以应用到各种业务场景。
  • 多线程编排:通过并行网关与异步任务,可以对多线程进行编排。
  • 流程设计:支持导入导出,可视化编辑流程图
  • 插件功能:提供redis,excel和mybatis插件,并拥有自定义插件拓展

3. 界面

自定义插件

static/img_6.png

excel插件

redis插件

mybatis插件

简化版下单逻辑

static/img_7.png

4. runflow设计初衷

一个功能刚开始比较简单,随着后面的不断迭代完善,功能越来越复杂。

比如下单功能,刚开始功能只是 验证必填项-库存预占-生成订单,

后面经过一年的不断迭代变成了 验证必填项-用户校验-风控校验-拆单-优惠信息-库存预占-生成订单(真实步骤远比这些多,这里简化了)

假设在接着迭代功能,看着动辄几千行的的代码,开发的小伙伴一定头皮发麻吧。产品的小伙伴也不好受,需要重新梳理流程步骤。

在这种情况下,runflow诞生了,可以图形化编排任务,对于开发来说,代码拆分成一个个步骤,更方便维护。产品也可以直接看流程图,更高效的进行设计。

5. runflow与activiti,flowable的区别

activiti,flowable 是基于角色任务流转的,runflow是基于逻辑流转的。

比如 订单流程 下单-审核-发货-确认收货。

activiti,flowable可以控制整个订单流程的运转。

runflow擅长控制下单流程里面的某个任务里面的步骤,比如订单流程里面的 下单有 验证必填项-用户校验-风控校验-拆单-优惠信息-库存预占-生成订单 七个步骤 runflow可以对里面的步骤进行编排。

6. 快速开始

Step1: 流程

S1.1: 流程设计

有一个五个任务串行执行的流程图demo1

img_3.png

下载文件:demo1.bpmn 放到resouces里面

目录结构如下

img.png

也可以用 http://123.249.93.130/runflow/ 在线设计自己的流程

S1.2: build

目前还没有上传到maven中央仓库,因此需要下载源码 安装到本地仓库

git clone https://github.com/songhongtu/runflow.git

mvn -Dmaven.test.failure.ignore=true clean install
 

S2.1: 调用流程(jar包方式)

2.1.1: 引入POM文件

<dependency>
    <groupId>com.runflow</groupId>
    <artifactId>runflow-core</artifactId>
    <version>0.0.2-Beta</version>
</dependency>
 

2.1.2: 调用流程

    ProcessEngineConfigurationImpl conf = new ProcessEngineConfigurationImpl();
    RunTimeServiceImpl runTimeService;

    {
        //初始化
        conf.init();
        runTimeService = conf.getRunTimeService();
        //bpmn位置
        conf.addPath("/bpmn/demo1.bpmn");
    }

    @Test
    public void demo1() {
        //a.incrementAndGet()
        AtomicInteger integer = new AtomicInteger(0);
        Map map = new HashMap();
        map.put("a", integer);
        runTimeService.startWorkflow("Process_1671936597549", map);
        System.out.println(integer);
    }
 

直接运行即可

img_4.png

S3.1: 调用流程(springboot方式)

3.1.1: 引入POM文件

<dependency>
    <groupId>com.runflow</groupId>
    <artifactId>runflow-spring-boot-starters</artifactId>
    <version>0.0.2-Beta</version>
</dependency>
 

3.1.2: 调用流程

   @Autowired
   RunTimeServiceImpl runTimeService;
   
    @GetMapping("/demo1")
    public Integer demo1(){
        AtomicInteger integer = new AtomicInteger(0);
        Map map = new HashMap();
        map.put("a", integer);
        runTimeService.startWorkflow("Process_1671936597549",map);
        System.out.println(integer.get());
        return integer.get();
    }
 

7.项目结构

runflow-core                                               [核心模块]
runflow-spring                                             [spring模块]
runflow-spring-boot-starters                               [springboot模块]
plugin/runflow-plugin-redis                                [redis插件]
plugin/runflow-plugin-mybatis                              [mybatis插件]
plugin/runflow-plugin-excel                                [excel插件]
runflow-springboot-demo                                    [springboot例子]


 

欢迎提出更好的意见,帮助完善 runflow

浏览 19
点赞
评论
收藏
分享

手机扫一扫分享

编辑 分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

编辑 分享
举报