LiteFlow规则引擎框架

2024-02-09 21:28
文章标签 引擎 规则 框架 liteflow

本文主要是介绍LiteFlow规则引擎框架,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

LiteFlow规则引擎框架

Hi,我是阿昌,今天介绍一个规则引擎框架,LiteFlow;

一、前言

那首先得知道什么是规则引擎?规则引擎是 一种用于自动化处理业务规则的软件组件。

在软件行业中,规则引擎通常用于解决复杂的业务逻辑处理问题。它可以将业务规则从应用程序中分离出来,并以一种易于管理维护的方式进行配置和修改。

规则引擎能够根据预先定义的规则集对输入数据进行评估和处理,并根据规则的结果执行相应的操作。这样可以提高软件系统的灵活性、可扩展性和可维护性。

规则引擎在许多软件领域都有广泛的应用,比如金融行业的风险评估、保险业的理赔处理、电子商务的促销活动等。

一些拥有复杂业务逻辑的系统,这些系统承载着核心业务逻辑,几乎每个需求都和这些核心业务有关,这些核心业务业务逻辑冗长,涉及内部逻辑运算,缓存操作,持久化操作,外部资源调取,内部其他系统RPC调用等等。时间一长,项目几经易手,维护成本就会越来越高。各种硬代码判断,分支条件越来越多。

代码的抽象,复用率也越来越低,各个模块之间的耦合度很高。一小段逻辑的变动,会影响到其他模块,需要进行完整回归测试来验证。

如要灵活改变业务流程的顺序,则要进行代码大改动进行抽象,重新写方法。实时热变更业务流程,几乎很难实现,那LiteFlow为解耦逻辑而生,为编排而生。


二、优势

  • 一个编排式的规则引擎框架,组件编排,帮助解耦业务代码,让每一个业务片段都是一个组件。
    • 可以将瀑布流式的代码,转变成以组件为核心概念的代码结构,这种结构的好处是可以任意编排,组件与组件之间是解耦的,组件可以用脚本来定义,组件之间的流转全靠规则来驱动。
    • LiteFlow拥有开源规则引擎最为简单的DSL语法
      在这里插入图片描述
  • 组件可实时热更替,也可以给编排好的逻辑流里实时增加一个组件,从而改变你的业务逻辑。
    在这里插入图片描述
  • 支持众多脚本语言,完全和Java打通,你可以用脚本来实现任何逻辑。
    在这里插入图片描述
  • 配置存放灵活,支持把编排规则和脚本放在数据库,注册中心中,还有可以任意扩展的接口,方便定制。
    在这里插入图片描述
  • 同时要保证所有组件都是灵活可变的。
    在这里插入图片描述

三、场景情况

1、适用场景

LiteFlow适用于拥有复杂逻辑的业务,比如说价格引擎,下单流程等,这些业务往往都拥有很多步骤,这些步骤完全可以按照业务粒度拆分成一个个独立的组件,进行装配复用变更。

可得到一个灵活度高,扩展性很强的系统。

因为组件之间相互独立,也可以避免改一处而动全身的这样的风险。

2、不适用场景

LiteFlow只做基于逻辑的流转,而不做基于角色任务的流转。如果你想做基于角色任务的流转,推荐使用flowable (opens new window),activiti (opens new window)这2个框架。


四、HelloWorld

liteflow支持多种框架的引入,场景的springboot、spring或非spring场景

1、前置版本

下面的代码是基于此版本进行演示:

  • springboot:2.3.4.RELEASE
  • jdk:1.8
  • liteflow-springboot:2.11.4.2

2、依赖

LiteFlow提供了liteflow-spring-boot-starter依赖包,提供自动装配功能

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

3、组件定义

在依赖了以上jar包后,需要定义并实现一些组件,确保SpringBoot会扫描到这些组件并注册进上下文。
定义如下:a,b,c组件

/*** @author achang* @date 2024/2/8 - 12:27 下午**/
@Component(value = "a")
public class AComponent extends NodeComponent {@Overridepublic void process() throws Exception {System.out.println("do A");}
}
/*** @author achang* @date 2024/2/8 - 12:27 下午**/
@Component(value = "b")
public class BComponent extends NodeComponent {@Overridepublic void process() throws Exception {System.out.println("do B");}
}
/*** @author achang* @date 2024/2/8 - 12:27 下午**/
@Component(value = "c")
public class CComponent extends NodeComponent {@Overridepublic void process() throws Exception {System.out.println("do C");}}

4、springboot配置

在SpringBoot的application.properties或者application.yml里添加配置(这里以properties为例,yaml也是一样的),更多的配置项

liteflow.rule-source=config/flow.el.xml

5、流程规则编写

在上面flow.el.xml文件中编写流程规则

<?xml version="1.0" encoding="UTF-8"?>
<flow><chain name="achang">THEN(a, b, c);</chain>
</flow>

SpringBoot在启动时会自动装载规则文件。

6、测试执行

编写测试执行类

/*** @author achang (caimu.zyc@raycloud.com)* @date 2024/2/8 - 12:34 下午* 执行测试组件**/
@Component("testHandleComponent")
public class TestHandleComponent {@Resourceprivate FlowExecutor flowExecutor;public void testHandle(String arg){LiteflowResponse liteflowResponse = flowExecutor.execute2Resp("tagChain", arg);System.out.println("done");}}

提示
这个DefaultContext是默认的上下文,用户可以用最自己的任意Bean当做上下文传入,如果需要传入自己的上下文,则需要传用户Bean的Class属性,具体请看数据上下文这一章节。

编写测试入口:

@SpringBootTest
class LiteFlowDemoApplicationTests {@Autowiredprivate TestHandleComponent testHandleComponent;@Testvoid contextLoads() {testHandleComponent.testHandle("achang");}
}

执行结果控制台:
在这里插入图片描述
那这样子用liteflow写了一个最简单的一个demo,可以看到用代码定于组件的代码然后,在流程规则中编写对组件之间流程执行的编写,这样子就可以将业务之间抽象成一个一个的组件,然后进行编排解藕达成目的,

那liteflow还有很多的高级特性,如:配置源的设置/多重组件的编写/EL规则的写法/数据上下文的玩法/执行器/脚本组件等等等等特性,在官方文档都有介绍,有兴趣的可以看:LiteFlow


这篇关于LiteFlow规则引擎框架的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/695325

相关文章

修改若依框架Token的过期时间问题

《修改若依框架Token的过期时间问题》本文介绍了如何修改若依框架中Token的过期时间,通过修改`application.yml`文件中的配置来实现,默认单位为分钟,希望此经验对大家有所帮助,也欢迎... 目录修改若依框架Token的过期时间修改Token的过期时间关闭Token的过期时js间总结修改若依

关于Gateway路由匹配规则解读

《关于Gateway路由匹配规则解读》本文详细介绍了SpringCloudGateway的路由匹配规则,包括基本概念、常用属性、实际应用以及注意事项,路由匹配规则决定了请求如何被转发到目标服务,是Ga... 目录Gateway路由匹配规则一、基本概念二、常用属性三、实际应用四、注意事项总结Gateway路由

Redis 多规则限流和防重复提交方案实现小结

《Redis多规则限流和防重复提交方案实现小结》本文主要介绍了Redis多规则限流和防重复提交方案实现小结,包括使用String结构和Zset结构来记录用户IP的访问次数,具有一定的参考价值,感兴趣... 目录一:使用 String 结构记录固定时间段内某用户 IP 访问某接口的次数二:使用 Zset 进行

Python基于火山引擎豆包大模型搭建QQ机器人详细教程(2024年最新)

《Python基于火山引擎豆包大模型搭建QQ机器人详细教程(2024年最新)》:本文主要介绍Python基于火山引擎豆包大模型搭建QQ机器人详细的相关资料,包括开通模型、配置APIKEY鉴权和SD... 目录豆包大模型概述开通模型付费安装 SDK 环境配置 API KEY 鉴权Ark 模型接口Prompt

MyBatis框架实现一个简单的数据查询操作

《MyBatis框架实现一个简单的数据查询操作》本文介绍了MyBatis框架下进行数据查询操作的详细步骤,括创建实体类、编写SQL标签、配置Mapper、开启驼峰命名映射以及执行SQL语句等,感兴趣的... 基于在前面几章我们已经学习了对MyBATis进行环境配置,并利用SqlSessionFactory核

cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个?

跨平台系列 cross-plateform 跨平台应用程序-01-概览 cross-plateform 跨平台应用程序-02-有哪些主流技术栈? cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个? cross-plateform 跨平台应用程序-04-React Native 介绍 cross-plateform 跨平台应用程序-05-Flutte

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF

数据治理框架-ISO数据治理标准

引言 "数据治理"并不是一个新的概念,国内外有很多组织专注于数据治理理论和实践的研究。目前国际上,主要的数据治理框架有ISO数据治理标准、GDI数据治理框架、DAMA数据治理管理框架等。 ISO数据治理标准 改标准阐述了数据治理的标准、基本原则和数据治理模型,是一套完整的数据治理方法论。 ISO/IEC 38505标准的数据治理方法论的核心内容如下: 数据治理的目标:促进组织高效、合理地

ZooKeeper 中的 Curator 框架解析

Apache ZooKeeper 是一个为分布式应用提供一致性服务的软件。它提供了诸如配置管理、分布式同步、组服务等功能。在使用 ZooKeeper 时,Curator 是一个非常流行的客户端库,它简化了 ZooKeeper 的使用,提供了高级的抽象和丰富的工具。本文将详细介绍 Curator 框架,包括它的设计哲学、核心组件以及如何使用 Curator 来简化 ZooKeeper 的操作。 1

【Kubernetes】K8s 的安全框架和用户认证

K8s 的安全框架和用户认证 1.Kubernetes 的安全框架1.1 认证:Authentication1.2 鉴权:Authorization1.3 准入控制:Admission Control 2.Kubernetes 的用户认证2.1 Kubernetes 的用户认证方式2.2 配置 Kubernetes 集群使用密码认证 Kubernetes 作为一个分布式的虚拟