【java规则引擎】drools6.5.0中kie的概论

简介: 什么是KIE?KIE是jBoss里面一些相关项目的统称,下图就是KIE代表的一些项目,其中我们比较熟悉的就有jBPM和Drools。这些项目都有一定的关联关系,并且存在一些通用的API,比如说涉及到构建(building)、部署(deploying)和加载 (loading)等方面的,这些API就都会以KIE作为前缀来表示这些是通用的API。

什么是KIE?

KIE是jBoss里面一些相关项目的统称,下图就是KIE代表的一些项目,其中我们比较熟悉的就有jBPM和Drools。

这些项目都有一定的关联关系,并且存在一些通用的API,比如说涉及到构建(building)、部署(deploying)和加载 (loading)等方面的,这些API就都会以KIE作为前缀来表示这些是通用的API。前面看到的一些KieServices、 KieContainer、KieSession类就都是KIE的公共API。

总的来说,就是jBoss通过KIE将jBPM和Drools等相关项目进行了一个整合,统一了他们的使用方式。像KieServices这些KIE类就是整合后的结果,在Drools中这样使用,在jBPM里面也是这样使用。

3、KIE项目生命周期

一个Drools应用项目其实就是一个KIE项目,KIE的生命周期其实就是Drools和jBPM这些项目的生命周期。

KIE项目生命周期包含:编写(Author)、构建(Build)、测试(Test)、部署(Deploy)、使用(Utilize)、执行(Run)、交互(Work)、管理(Manage)。

  1. 编写:编写就是编写规则文件或者流程文件;
  2. 构建:就是构建一个可以发布部署的组件,在KIE中就是构建一个jar文件;
  3. 测试:在部署到应用程序之前需要对规则或者流程进行测试;
  4. 部署:就是将jar部署到应用程序,KIE利用Maven仓库来进行发布和部署;
  5. 使用:就是加载jar文件,并通过KieContainer对jar文件进行解析,然后创建KieSession;
  6. 执行:系统通过KieSession对象的API跟Drools引擎进行交互,执行规则或者流程;
  7. 交互:用户通过命令行或者UI跟引擎进行交互;
  8. 管理:管理KieSession或者KieContainer对象。

4、KIE & Maven

通过前面的知识我们了解到Drools工程其实就是一个Maven工程,有着Maven工程标准的结构,然后Drools在这个基础上也定义了一个自己的存储结构:

drools的标准存储结构就是在src/main/resources文件夹下面存储规则文件(包括DRL文件和Excel文件),然后在META-INF文件夹下面创建一个kmodule.xml文件用来存储规则定义声明。

Drools项目最终都是打包成jar然后进行发布部署的(KIE项目生命周期提到的),这样定义工程结构和打包发布方式的根本原因就是——Maven!

上图描述了KIE项目(包括Drools)的打包、发布、部署过程,就是一个KIE项目按照上面定义的工程结构进行设计开发,然后通过mvn deploy命令发布到Maven仓库,然后应用程序可以通过mvn install将发布好的jar包下载安装到本地应用程序中,最后通过KieServices等API就可以直接使用这些发布好的规则了。

为什么我们写的JUnit Test类里面驱动一个规则的代码非常简单,就是因为Drools定义了上面的一套规范,按照规范来编写、发布、部署规则之后就可以确保以最简单的方式来使用Drools等KIE项目。这也是惯例优于配置的一种体现。

所以我们说一个Drools项目工程就是一个Maven项目工程,或者说一个KIE项目工程就是一个Maven工程。

KIE也提供了一种策略,能够让应用程序在运行时,能够动态监测Maven仓库中Drools项目jar组件的版本更新情况,然后可以根据配置动态更新Drools发布包,实现热插拔功能,这个是通过KieScanner API实现的。

 

编码方式实现

 1 public class KieFileSystemTest {
 2 
 3     @Test
 4     public void test() {
 5         KieServices kieServices = KieServices.Factory.get();
 6         KieResources resources = kieServices.getResources();
 7         KieModuleModel kieModuleModel = kieServices.newKieModuleModel();//1
 8 
 9         KieBaseModel baseModel = kieModuleModel.newKieBaseModel(
10                 "FileSystemKBase").addPackage("rules");//2
11         baseModel.newKieSessionModel("FileSystemKSession");//3
12         KieFileSystem fileSystem = kieServices.newKieFileSystem();
13 
14         String xml = kieModuleModel.toXML();
15         System.out.println(xml);//4
16         fileSystem.writeKModuleXML(xml);//5
17 
18         fileSystem.write("src/main/resources/rules/rule.drl", resources
19                 .newClassPathResource("kiefilesystem/KieFileSystemTest.drl"));//6
20 
21         KieBuilder kb = kieServices.newKieBuilder(fileSystem);
22         kb.buildAll();//7
23         if (kb.getResults().hasMessages(Level.ERROR)) {
24             throw new RuntimeException("Build Errors:\n"
25                     + kb.getResults().toString());
26         }
27         KieContainer kContainer = kieServices.newKieContainer(kieServices
28                 .getRepository().getDefaultReleaseId());
29 
30         assertNotNull(kContainer.getKieBase("FileSystemKBase"));
31         KieSession kSession = kContainer.newKieSession("FileSystemKSession");
32 
33         kSession.fireAllRules();
34     }
35 }
View Code

 

相关文章
|
6月前
|
监控 数据可视化 Java
【JAVA】分布式链路追踪技术概论
【JAVA】分布式链路追踪技术概论
86 2
|
6月前
|
数据可视化 Java
探索Drools:Java世界的规则引擎
探索Drools:Java世界的规则引擎
403 1
|
2月前
|
数据可视化 算法 Java
JAVA规则引擎工具
本文介绍了六款常用的Java规则引擎:Drools、IBM ODM、Easy Rules、jBPM、OpenL Tablets 和 Apache Camel。每款引擎都有其独特的特点和适用场景,如Drools的高效规则匹配、IBM ODM的Web界面管理、Easy Rules的轻量级特性、jBPM的流程管理、OpenL Tablets的Excel规则定义以及Apache Camel的路由和规则结合。选择合适的规则引擎可以显著提高系统的灵活性和可维护性。
144 0
|
5月前
|
算法 数据可视化 Java
JAVA规则引擎工具有哪些?
本文对比分析了六种Java规则引擎:Drools、IBM ODM (JRules)、Easy Rules、JBPM、OpenL Tablets以及Apache Camel结合规则组件的应用。Drools是一款功能全面的业务规则管理系统,支持DRL文件定义规则、高效的规则匹配算法、复杂的规则流及决策表,并易于与Java应用集成。IBM ODM (原JRules)提供了强大的规则管理功能,包括Web界面和Eclipse插件定义管理规则、直观的决策表和决策树、REST和Java API集成选项及优化的性能。
864 3
|
7月前
|
监控 数据可视化 Java
【JAVA】分布式链路追踪技术概论
skywalking拥有更加的强大和细粒度的图形监控界面。
108 2
|
7月前
|
监控 负载均衡 Java
深入探究Java微服务架构:Spring Cloud概论
**摘要:** 本文深入探讨了Java微服务架构中的Spring Cloud,解释了微服务架构如何解决传统单体架构的局限性,如松耦合、独立部署、可伸缩性和容错性。Spring Cloud作为一个基于Spring Boot的开源框架,提供了服务注册与发现、负载均衡、断路器、配置中心、API网关等组件,简化了微服务的开发、部署和管理。文章详细介绍了Spring Cloud的核心模块,如Eureka、Ribbon、Hystrix、Config、Zuul和Sleuth,并通过一个电商微服务系统的实战案例展示了如何使用Spring Cloud构建微服务应用。
103595 9
|
7月前
|
算法 安全 Java
Java表达式和规则引擎的比较与考量
Java表达式和规则引擎的比较与考量
391 0
|
存储 Java 应用服务中间件
Java规则引擎Drools急速入门
Java规则引擎Drools急速入门
Java规则引擎Drools急速入门
|
存储 Java 调度
手撕JAVA(2)多线程(1)概论
1.概念 程序 存储在磁盘上的一段指令的集合,是静态的。 进程 运行中的程序,指计算机在某个数据集合上的一次运行活动,每个进程都有独立的资源空间,是操作系统进行资源分配与调度的基本单位。 (数据集合包含两方便,一是数据,二是硬件资源,如CPU,IO等) 线程 又称轻量级进程,是为了提高资源利用率以及CPU的并发度,而对进程进行的一种优化。线程是进程中的一个个的实体,是进程的一个个的执行单元。同一进程的线程共享该进程的资源,即电脑所分配的资源空间。
96 0
|
Java 应用服务中间件 Maven
【Java】-一文带你入门Drools规则引擎
【Java】-一文带你入门Drools规则引擎
1394 0
【Java】-一文带你入门Drools规则引擎