zoukankan      html  css  js  c++  java
  • 【java规则引擎】drools6.5.0中kie的概论

    什么是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:
    "
    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
  • 相关阅读:
    【HDU 2093】考试排名(结构体水题)
    【HDU 2037】今年暑假不AC
    【HDU 1234】开门人和关门人(水题)
    【HDU 1005】Number Sequence
    第一篇博客——ACM之路!
    深度学习全家福
    搭建 keras + tensorflow
    MSCI 成份股 清单
    SK-Learn 全家福
    创业笔记 -- 网站正式对外运营
  • 原文地址:https://www.cnblogs.com/shangxiaofei/p/7117821.html
Copyright © 2011-2022 走看看