LiteFlow:国产流程编排引擎体验

文章目录

  • 一、写在前面
  • 二、使用
    • 1、Springboot集成
    • 2、组件
    • 3、表达式
    • 4、上下文
    • 5、执行器
    • 6、脚本组件
    • 7、规则配置源
    • 8、元数据管理
    • 9、异步中的线程池
    • 10、动态构造
    • 11、决策路由
    • 12、生命周期
    • 13、其他
  • 三、总结

一、写在前面

就不做过多介绍了。
官网:https://liteflow.cc/

二、使用

1、Springboot集成

(1)引包

<dependency><groupId>com.yomahub</groupId><artifactId>liteflow-spring-boot-starter</artifactId><version>2.15.0</version>
</dependency>

引入的jar包还不少呢:
在这里插入图片描述
(2)按照官网的demo来一套,发现确实挺好用:
文档:https://liteflow.cc/pages/9bf6be/#%E4%BE%9D%E8%B5%96

2、组件

(1)继承式组件的作用就是,提供了几个内置的,为流程编排提供了执行器、条件器、循环器等等。
文档:https://liteflow.cc/pages/8486fb/

(2)声明式组件,更灵活。感觉方法级别式声明更适合日常开发。
文档:https://liteflow.cc/pages/46f0fa/

3、表达式

文档:https://liteflow.cc/pages/16eca9/

表达式,就是进行流程编排了。

4、上下文

文档:https://liteflow.cc/pages/74b4bf/

在执行器执行流程时会分配数据上下文实例给这个请求。不同请求的数据上下文实例是完全隔离的。里面存放着此请求所有的用户数据。不同的组件之间是不传递参数的,所有的数据交互都是通过这个数据上下文来实现的。

使用的时候,最好是将上下文进行自定义:

OrderContext orderContext = new OrderContext();
orderContext.setOrderNo("SO11223344");
// 上下文已经初始化好参数了,就可以省略流程入参
LiteflowResponse response = flowExecutor.execute2Resp("chain1", null, orderContext);

上下支持将整个取出进行处理,也可以单独对类的字段进行处理。

5、执行器

文档:https://liteflow.cc/pages/90b2a5/

执行器是一个流程的触发点,你可以在代码的任意地方用执行器进行执行流程

需要注意执行器的出参、入参、上下文

流程多的话(几万+),需要设置保活策略。

6、脚本组件

需要经常更新+热部署的代码部分,可以考虑脚本组件。

7、规则配置源

文档:https://liteflow.cc/pages/51ddd5/#%E8%A7%84%E5%88%99%E6%96%87%E4%BB%B6

可以将规则配置在文件、数据库、配置中心等等很多地方,也支持热更新。

8、元数据管理

文档:https://liteflow.cc/pages/7cb165/

在LiteFlow框架中,最重要的两个概念就是规则以及组件。
框架提供了一个元数据管理器LiteflowMetaOperator用来管理这两大元素。

LiteFlow原生支持的zookeeper,etcd,nacos,apollo等插件,不需要你做任何事,只要规则更改之后,会自动热平滑刷新。
本地文件也支持热更新,需要配置本地文件监听。
sql,redis也会热更新,因为是轮训,所以会有延时。

9、异步中的线程池

文档:https://liteflow.cc/pages/3a3b69/

从2.13.0开始,框架中的线程池模型设计和之前的版本有较大的差异性,所以此章只适用于2.13.0之后的版本。

线程池分为流程级别的、组件异步级别的。
组件异步还分表达式级别、Chain级别。

JDK为21及以上时,默认使用虚拟线程。

10、动态构造

文档:https://liteflow.cc/pages/9aa85a/

Node、表达式、Chain都可以动态构造。

11、决策路由

文档:https://liteflow.cc/pages/ec1ac4/

感觉是没啥大用,还挺复杂的。

12、生命周期

文档:https://liteflow.cc/pages/ef098d/#%E8%A7%84%E5%88%99%E6%9E%84%E9%80%A0%E5%89%8D%E5%90%8E

13、其他

三、总结

业务复杂可以考虑引入,但是大部分项目应该还是不必须的。

LiteFlow主要还是以流程编排为主。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/97861.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/97861.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux学习:生产者消费者模型

目录1. 生产者消费者模型的相关概念1.1 什么是生产者消费者模型1.2 生产者消费者模型的优势作用2. 多线程简单实现生产者消费者模型2.1 设计方案2.2 代码实现2.2.1 线程类2.2.2 BlockQueue类2.2.3 任务类2.2.4 主干代码1. 生产者消费者模型的相关概念 1.1 什么是生产者消费者模…

《深度学习》卷积神经网络:数据增强与保存最优模型解析及实现

目录 一、数据增强 1. 核心概念 2. 核心目的 3. 常用方法 4. 实现示例&#xff08;基于 PyTorch&#xff09; 5. 自定义数据集加载 二、保存最优模型 1. 核心概念 2. 实现步骤 &#xff08;1&#xff09;定义 CNN 模型 &#xff08;2&#xff09;定义训练与测试函数…

tcpdump用法

tcpdump用法tcpdump一、什么是tcpdump二、命令格式与参数三、参数列表四、过滤规则组合逻辑运算符过滤器关键字理解 Flag 标识符五、常用例子tcpdump 一、什么是tcpdump 二、命令格式与参数 option 可选参数&#xff1a;将在后边一一解释。 proto 类过滤器&#xff1a;根据协…

平衡车 - 电机调速

&#x1f308;个人主页&#xff1a;羽晨同学 &#x1f4ab;个人格言:“成为自己未来的主人~” 在我们的这篇文章当中&#xff0c;我们主要想要实现的功能的是电机调速功能。在我们的这篇文章中&#xff0c;主要实现的是开环的功能&#xff0c;而非闭环&#xff0c;也就是不加…

从利润率看价值:哪些公司值得长期持有?

&#x1f4a1; 为什么盯紧利润率&#xff1f; 投资者常常盯着营收增长&#xff0c;却忽略了一个更关键的指标——利润率。 收入可以靠规模“堆”出来&#xff0c;但利润率却是企业护城河的真实体现。心理学研究表明&#xff1a;当一个产品或服务被消费者认定为“不可替代”&a…

小迪web自用笔记25

传统文件上传&#xff1a;上传至服务器本身硬盘。云存储&#xff1a;借助云存储oss对象存储&#xff08;只能被访问&#xff0c;不可解析&#xff09;Oss云存储Access key与Access ID&#xff1a;有了这两个东西之后就可以操作云存储&#xff0c;可以向里面发数据了。这玩意儿泄…

分发饼干——很好的解释模板

好的&#xff0c;孩子&#xff0c;我们来玩一个“喂饼干”的游戏。 0. 问题的本质是什么&#xff1f; 想象一下&#xff0c;你就是个超棒的家长&#xff0c;手里有几块大小不一的饼干&#xff0c;而面前有几个饿着肚子的小朋友。每个小朋友都有一个最小的“胃口”值&#xff0c…

场景题:如果一个大型项目,某一个时间所有的CPU的已经被占用了,导致服务不可用,我们开发人员应该如何使服务器尽快恢复正常

问&#xff1a;如果一个大型项目,某一个时间所有的CPU的 已经被占用了&#xff0c;导致服务不可用&#xff0c;我们开发人员 应该如何使服务器尽快恢复正常答&#xff1a;应对CPU 100%导致服务不可用的紧急恢复流程面试官&#xff0c;如果遇到这种情况&#xff0c;我会立即按照…

Docker 安装 RAGFlow保姆教程

前提条件 Ubuntu 服务器(20.04 或 22.04 LTS 推荐) 已安装 Docker 和 Docker Compose 如果尚未安装,请先运行以下命令:# 安装 Docker curl -fsSL https://get.docker.com -o get-docker.sh sudo sh get-docker.sh # 将当前用户加入 docker 组,避免每次都要 sudo sudo user…

为什么实际工程里 C++ 部署深度学习模型更常见?为什么大家更爱用 TensorRT?

很多人刚接触深度学习模型部署的时候&#xff0c;都会习惯用 Python&#xff0c;因为训练的时候就是 PyTorch、TensorFlow 啊&#xff0c;写起来方便。但一到 实际工程&#xff0c;特别是工业设备、医疗影像、上位机系统这种场景&#xff0c;你会发现大多数人都转向了 C 部署。…

深入理解 Java 集合框架:底层原理与实战应用

在日常开发中&#xff0c;集合是 Java 中使用频率最高的工具之一。从最常见的 ArrayList、HashMap 到更复杂的并发集合&#xff0c;几乎每一个 Java 程序员都离不开集合框架。集合框架不仅提供了丰富的数据结构实现&#xff0c;还封装了底层复杂的逻辑&#xff0c;让开发者能够…

爬取m3u8视频完整教程

爬取步骤&#xff1a;1.先找到网页源代码2.从网页源代码中拿到m3u83.下载m3u84.读取m3u8文件&#xff0c;下载视频5.合并视频首先我们来爬取一个星辰影院的电影&#xff1a;下面我以这个为例&#xff1a;我们需要在源代码中找到m3u8这个url&#xff1a;紧接着我们利用下面的方法…

Python爬虫实战: 基于Scrapy的Amazon跨境电商选品数据爬虫方案

概述与设计思路 利用Python的Scrapy框架进行大规模页面抓取和结构化数据提取,配合aiohttp实现高并发请求,从而高效获取Amazon平台上的商品列表、详情、评论等公开信息。通过对这些数据进行清洗与分析,可以识别出有潜力的商品,评估市场竞争程度,并跟踪竞争对手的动态,为跨…

稳定版IM即时通讯 仿默往APP即时通讯im源码聊天社交源码支持二开原生开发独立部署 含搭建教程

内容目录一、详细介绍二、效果展示1.部分代码2.效果图展示三、学习资料下载一、详细介绍 技术开发语言&#xff1a; 后台管理端&#xff1a;Java GO Mysql数据库 安卓端&#xff1a;Java iOS端&#xff1a;ob PC端&#xff1a;c 功能简单介绍&#xff1a; 单聊&#xff…

封装一个redis获取并解析数据的工具类

redis获取并解析数据工具类实现代码使用示例实现代码 import cn.hutool.core.collection.CollUtil; import cn.hutool.core.util.ObjectUtil; import cn.hutool.core.util.StrUtil; import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.TypeReference; import lom…

23种设计模式——策略模式 (Strategy Pattern)​详解

✅作者简介&#xff1a;大家好&#xff0c;我是 Meteors., 向往着更加简洁高效的代码写法与编程方式&#xff0c;持续分享Java技术内容。 &#x1f34e;个人主页&#xff1a;Meteors.的博客 &#x1f49e;当前专栏&#xff1a;设计模式 ✨特色专栏&#xff1a;知识分享 &#x…

CI(持续集成)、CD(持续交付/部署)、CT(持续测试)、CICD、CICT

目录 **CI、CD、CT 详解与关系** **1. CI(Continuous Integration,持续集成)** **2. CD(Continuous Delivery/Deployment,持续交付/部署)** **持续交付(Continuous Delivery)** **持续部署(Continuous Deployment)** **3. CT(Continuous Testing,持续测试)** **4.…

【音视频】WebRTC ICE 模块深度剖析

原文链接&#xff1a; https://mp.weixin.qq.com/s?__bizMzIzMjY3MjYyOA&mid2247498075&idx2&sn6021a2f60b1e7c71ce4d7af6df0b9b89&chksme893e540dfe46c56323322e780d41aec1f851925cfce8b76b3f4d5cfddaa9c7cbb03a7ae4c25&scene178&cur_album_id314699…

linux0.12 head.s代码解析

重新设置IDT和GDT&#xff0c;为256个中断门设置默认的中断处理函数检查A20地址线是否启用设置数学协处理器将main函数相关的参数压栈设置分页机制&#xff0c;将页表映射到0~16MB的物理内存上返回main函数执行 源码详细注释如下: /** linux/boot/head.s** (C) 1991 Linus T…

Maven动态控制版本号秘籍:高效发包部署,版本管理不再头疼!

作者&#xff1a;唐叔在学习 专栏&#xff1a;唐叔的Java实践 关键词&#xff1a;Maven版本控制、versions插件、动态版本号、持续集成、自动化部署、Java项目管理 摘要&#xff1a;本文介绍如何使用Maven Versions插件动态控制项目版本号和依赖组件版本号&#xff0c;实现无需…