`

java规则引擎你应该知道的几点东西,不妨来看看呦!

阅读更多

由于时间的问题,已经很久没有来写东西,突然写起来还有点手生,今天来给大家讲一下有关java的规则引擎的一些东西,比如向开源的drools等等,好了,废话不多说了,大家一起来看看。

规则引擎的原理

  1、基于规则的专家系统(RBES)简介

  Java规则引擎起源于基于规则的专家系 统,而基于规则的专家系统又是专家系统的其中一个分支。专家系统属于人工智能的范畴,它模仿人类的推理方式,使用试探性的方法进行推理,并使用人类能理解 的术语解释和证明它的推理结论。为了更深入地了解Java规则引擎,下面简要地介绍基于规则的专家系统。RBES包括三部分:Rule Baseknowledge base)、Working Memoryfact base)和Inference Engine。它们的结构如下系统所示:

1 基于规则的专家系统构成


   如图1所示,推理引擎包括三部分:模式匹配器(Pattern Matcher)、议程(Agenda)和执行引擎(Execution Engine)。推理引擎通过决定哪些规则满足事实或目标,并授予规则优先级,满足事实或目标的规则被加入议程。模式匹配器决定选择执行哪个规则,何时执 行规则;议程管理模式匹配器挑选出来的规则的执行次序;执行引擎负责执行规则和其他动作。

  和人类的思维相对应,推理引擎存在两者推理 方式:演绎法(Forward-Chaining)和归纳法(Backward-Chaining)。演绎法从一个初始的事实出发,不断地应用规则得出结 论(或执行指定的动作)。而归纳法则是根据假设,不断地寻找符合假设的事实。Rete算法是目前效率最高的一个Forward-Chaining推理算 法,许多Java规则引擎都是基于Rete算法来进行推理计算的。

  推理引擎的推理步骤如下:

  (1)将初始数据(fact)输入Working Memory

  (2)使用Pattern Matcher比较规则库(rule base)中的规则(rule)和数据(fact)。

  (3)如果执行规则存在冲突(conflict),即同时激活了多个规则,将冲突的规则放入冲突集合。

  (4)解决冲突,将激活的规则按顺序放入Agenda

  (5)使用执行引擎执行Agenda中的规则。重复步骤25,直到执行完毕所有Agenda中的规则。

  上述即是规则引擎的原始架构,Java规则引擎就是从这一原始架构演变而来的。

  2、规则引擎相关构件

  规则引擎是一种根据规则中包含的指定过滤条件,判断其能否匹配运行时刻的实时条件来执行规则中所规定的动作的引擎。与规则引擎相关的有四个基本概念,为更好地理解规则引擎的工作原理,下面将对这些概念进行逐一介绍。

  1)信息元(Information Unit

  信息元是规则引擎的基本建筑块,它是一个包含了特定事件的所有信息的对象。这些信息包括:消息、产生事件的应用程序标识、事件产生事件、信息元类型、相关规则集、通用方法、通用属性以及一些系统相关信息等等。

  2)信息服务(Information Services

   信息服务产生信息元对象。每个信息服务产生它自己类型相对应的信息元对象。即特定信息服务根据信息元所产生每个信息元对象有相同的格式,但可以有不同的 属性和规则集。需要注意的是,在一台机器上可以运行许多不同的信息服务,还可以运行同一信息服务的不同实例。但无论如何,每个信息服务只产生它自己类型相 对应的信息元。

  3)规则集(Rule Set

  顾名思义,规则集就是许多规则的集合。每条规则包含一个条件过滤 器和多个动作。一个条件过滤器可以包含多个过滤条件。条件过滤器是多个布尔表达式的组合,其组合结果仍然是一个布尔类型的。在程序运行时,动作将会在条件 过滤器值为真的情况下执行。除了一般的执行动作,还有三类比较特别的动作,它们分别是:放弃动作(Discard Action)、包含动作(Include Action)和使信息元对象内容持久化的动作。前两种动作类型的区别将在2.3规则引擎工作机制小节介绍。

  4)队列管理器(Queue Manager

  队列管理器用来管理来自不同信息服务的信息元对象的队列。

  下面将研究规则引擎的这些相关构件是如何协同工作的。

  如图2所示,处理过程分为四个阶段进行:信息服务接受事件并将其转化为信息元,然后这些信息元被传给队列管理器,最后规则引擎接收这些信息元并应用它们自身携带的规则加以执行,直到队列管理器中不再有信息元。


2 处理过程协作图


  3、规则引擎的工作机制

   下面专门研究规则引擎的内部处理过程。如图3所示,规则引擎从队列管理器中依次接收信息元,然后依规则的定义顺序检查信息元所带规则集中的规则。如图所 示,规则引擎检查第一个规则并对其条件过滤器求值,如果值为假,所有与此规则相关的动作皆被忽略并继续执行下一条规则。如果第二条规则的过滤器值为真,所 有与此规则相关的动作皆依定义顺序执行,执行完毕继续下一条规则。该信息元中的所有规则执行完毕后,信息元将被销毁,然后从队列管理器接收下一个信息元。 在这个过程中并未考虑两个特殊动作:放弃动作(Discard Action)和包含动作(Include Action)。放弃动作如果被执行,将会跳过其所在信息元中接下来的所有规则,并销毁所在信息元,规则引擎继续接收队列管理器中的下一个信息元。包含动 作其实就是动作中包含其它现存规则集的动作。包含动作如果被执行,规则引擎将暂停并进入被包含的规则集,执行完毕后,规则引擎还会返回原来暂停的地方继续 执行。这一过程将递归进行。

 

                          图3 规则引擎工作机制

   Java规则引擎的工作机制与上述规则引擎机制十分类似,只不过对上述概念进行了重新包装组合。Java规则引擎对提交给引擎的Java数据对象进行检 索,根据这些对象的当前属性值和它们之间的关系,从加载到引擎的规则集中发现符合条件的规则,创建这些规则的执行实例。这些实例将在引擎接到执行指令时、 依照某种优先序依次执行。一般来讲,Java规则引擎内部由下面几个部分构成:工作内存(Working Memory)即工作区,用于存放被引擎引用的数据对象集合;规则执行队列,用于存放被激活的规则执行实例;静态规则区,用于存放所有被加载的业务规则, 这些规则将按照某种数据结构组织,当工作区中的数据发生改变后,引擎需要迅速根据工作区中的对象现状,调整规则执行队列中的规则执行实例。Java规则引 擎的结构示意图如图4所示。

 


   当引擎执行时,会根据规则执行队列中的优先顺序逐条执行规则执行实例,由于规则的执行部分可能会改变工作区的数据对象,从而会使队列中的某些规则执行实 例因为条件改变而失效,必须从队列中撤销,也可能会激活原来不满足条件的规则,生成新的规则执行实例进入队列。于是就产生了一种动态的规则执行链,形 成规则的推理机制。这种规则的链式反应完全是由工作区中的数据驱动的。

  任何一个规则引擎都需要很好地解决规则的推理机制和规则 条件匹配的效率问题。规则条件匹配的效率决定了引擎的性能,引擎需要迅速测试工作区中的数据对象,从加载的规则集中发现符合条件的规则,生成规则执行实 例。1982年美国卡耐基·梅隆大学的Charles L. Forgy发明了一种叫Rete算法,很好地解决了这方面的问题。目前世界顶尖的商用业务规则引擎产品基本上都使用Rete算法。

Java规则引擎API——JSR-94

  为了使规则引擎技术标准化,Java社区制定了Java规则引擎APIJSR94)规范。它为Java平台访问规则引擎定义了一些简单的API

   Java规则引擎APIjavax.rules包中定义,是访问规则引擎的标准企业级APIJava规则引擎API允许客户程序使用统一的方式和不 同厂商的规则引擎产品交互,就如同使用JDBC编写独立于厂商访问不同的数据库产品一样。Java规则引擎API包括创建和管理规则集合的机制,在工作区 中添加,删除和修改对象的机制,以及初始化,重置和执行规则引擎的机制。

  1Java规则引擎API体系结构

  Java规则引擎API主要由两大类API组成: 规则管理API(The Rules Administrator API)和运行时客户API(The Runtime Client API)

  1)规则管理API

   规则管理APIjavax.rules.admin中定义,包含装载规则以及与规则对应的动作(执行集 execution sets)以及实例化规则引擎。规则可以从外部资源中装载,比如URIInput streams XML streamsreaders等等。同时规则管理API还提供了注册和取消注册执行集以及对执行集进行维护的机制。使用admin包定义规则有助于对客 户访问运行规则进行控制管理,它通过在执行集上定义许可权使得未经授权的用户无法访问受控规则。

  规则管理API使用类 RuleServiceProvider来获得规则管理器(RuleAdministrator)接口的实例。该接口提供方法注册和取消注册执行集。规则 管理器提供了本地和远程的RuleExecutionSetProvider,它负责创建规则执行集(RuleExecutionSet)。规则执行集可 以从如XML streams binary streams等来源中创建。这些数据来源及其内容经汇集和序列化后传送到远程的运行规则引擎的服务器上。在大多数应用 序中,远程规则引擎或远程规则数据来源的情况并不多。为了避免这些情况中的网络开销,API规定了可以从运行在同一JVM中规则库中读取数据的本地 RuleExecutionSetProvider。规则执行集接口除了拥有能够获得有关规则执行集的方法,还有能够检索在规则执行集中定义的所有规则对 象。这使得客户能够知道规则集中的规则对象并且按照自己需要来使用它们。

  2)运行时客户API

  运行时APIjavax.rules包中定义,为规则引擎用户运行规则获得结果提供了类和方法。运行时客户只能访问那些使用规则管理API注册过的规则,运行时API帮助用户获得规则会话,并在这个会话中执行规则。

   运行时API提供了对厂商规则引擎API的访问方法,这类似于JDBC。类RuleServiceProvider提供了对具体规则引擎实现的运行时和 管理API的访问,规则引擎厂商通过该类将其规则引擎实现提供给客户,并获得RuleServiceProvider唯一标识规则引擎的URL。此URL 的标准用法是使用类似于“com.mycompany.myrulesengine.rules.RuleServiceProvider”这样的 Internet域名空间,这保证了访问URL的唯一性。类RuleServiceProvider内部实现了规则管理和运行时访问所需的接口。所有的 RuleServiceProvider要想被客户所访问都必须用RuleServiceProviderManager进行注册,注册方式类似于 JDBC APIDriverManagerDriver

  运行时接口是运行时API的关键部分。运行时接口提供了用于创建规则 会话(RuleSession)的方法,规则会话是用来运行规则的。运行时API同时也提供了访问在service provider注册过的所有规则执行集(RuleExecutionSets)。规则会话接口定义了客户使用的会话的类型,客户根据自己运行规则的方式 可以选择使用有状态会话或者无状态会话。无状态会话的工作方式就像一个无状态会话bean。客户可以发送单个输入对象或一列对象来获得输出对象。当客户需 要一个与规则引擎间的专用会话时,有状态会话就很有用。输入的对象通过addObject() 方法可以加入到会话当中。同一个会话当中可以加入多个对象。对话中已有对象可以通过使用updateObject()方法得到更新。只要客户与规则引擎间 的会话依然存在,会话中的对象就不会丢失。

  RuleExecutionSetMetaData接口提供给客户让其查找规则执行集的元数据(metadata)。元数据通过规则会话接口(RuleSession Interface)提供给用户。

  2Java规则引擎API安全问题

   规则引擎API将管理API和运行时API加以分开,从而为这些包提供了较好粒度的安全控制。规则引擎API并没有提供明显的安全机制,它可以和 J2EE规范中定义的标准安全API联合使用。安全可以由以下机制提供,如Java 认证和授权服务 (JAAS)Java加密扩展(JCE)Java安全套接字扩展(JSSE),或者其它定制的安全API。使用JAAS可以定义规则执行集的许可权 限,从而只有授权用户才能访问。

  3、异常与日志

  规则引擎API定义了 javax.rules.RuleException作为规则引擎异常层次的根类。所有其它异常都继承于这个根类。规则引擎中定义的异常都是受控制的异常 (checked exceptions),所以捕获异常的任务就交给了规则引擎。规则引擎API没有提供明确的日志机制,但是它建议将Java Logging API用于规则引擎API

  JSR 94 为规则引擎提供了公用标准API,仅仅为实现规则管理API和运行时API提供了指导规范,并没有提供规则和动作该如何定义以及该用什么语言定义规则,也没有为规则引擎如何读和评价规则提供技术性指导。

 

最后,如果想学习更多java知识的朋友给你们推荐59biyejava教程,好了希望对你们有所帮助。

3
3
分享到:
评论
2 楼 骨之灵魂 2014-09-15  
11miao 写道
有点深奥,有点看不太懂,呵呵!!!

1 楼 11miao 2014-09-15  
有点深奥,有点看不太懂,呵呵!!!

相关推荐

    Java游戏服务端执行引擎.zip

    从描述来看,这个执行引擎应该是可以直接运行的,这意味着它包含了所有必要的运行时环境和配置文件,用户只需解压即可启动服务。 Java作为一款跨平台的编程语言,因其优秀的性能和强大的生态系统,在游戏服务端开发...

    JAVA上百实例源码以及开源项目源代码

    Java局域网通信——飞鸽传书源代码 28个目标文件 内容索引:JAVA源码,媒体网络,飞鸽传书 Java局域网通信——飞鸽传书源代码,大家都知道VB版、VC版还有Delphi版的飞鸽传书软件,但是Java版的确实不多,因此这个Java...

    java伪静态简单实例

    总结一下,Java中的伪静态简单实例主要涉及以下几个知识点: 1. **伪静态**:一种提高搜索引擎友好度的技术,通过将动态URL转换为静态形式。 2. **URL重写**:改变URL的显示方式,但不改变其实际功能。 3. **url...

    架构设计java1

    为了优化性能和扩展性,可能还需要考虑以下几点: - **负载均衡**:使用负载均衡器分发流量到多个服务器,避免单点故障。 - **缓存**:利用Redis或Memcached等缓存系统,减轻数据库压力,提高响应速度。 - **微服务*...

    excel导入导出资源引擎

    6. **运维管理**:从文件列表中的"02运维管理"来看,可能包含关于如何维护和监控引擎的文档,包括日志分析、故障排查、性能监控等内容,这些都是确保系统稳定运行的关键。 7. **安装部署**:"01安装部署"可能提供...

    Efs.rar_efs_java 工作流

    在IT领域,工作流引擎是一个关键组件,它能够根据预定义的规则和流程来协调任务的执行。 描述中提到,这个“Efs”工作流系统相比JBP(Job Broker for Java)更为简单,且易于上手。JBP是一种流行的工作流管理系统,...

    java/jsp网站实现伪静态

    实现伪静态后,还需要注意以下几点: - **SEO优化**:伪静态URL对于搜索引擎更加友好,有助于提升网站的搜索引擎排名。 - **缓存策略**:静态化的URL可以利用浏览器缓存和CDN服务,提高页面访问速度。 - **维护和...

    超级有影响力霸气的Java面试题大全文档

    从内存方面来看, Stateful Session Bean 与 Stateless Session Bean 比较, Stateful Session Bean 会消耗 J2EE Server 较多的内存,然而 Stateful Session Bean 的优势却在于他可以维持使用者的状态。 12、...

    理解虚拟机--有笔记版

    在深入探讨JVM的高级特性和最佳实践之前,我们先来看看与Java虚拟机相关的几个重要知识点。 首先,JVM的内存模型是非常重要的一个概念。JVM内存模型定义了程序中各种变量的访问规则,它包含了堆(Heap)、栈(Stack...

    DRools BRMS Rule创建问题?

    在IT行业中,规则引擎是一种非常重要的工具,它允许开发者通过定义业务规则来自动化决策过程,而无需编写大量的代码。Drools是Red Hat提供的一款开源BRMS(Business Rule Management System,业务规则管理系统),它...

    java面试题,180多页,绝对良心制作,欢迎点评,涵盖各种知识点,排版优美,阅读舒心

    180多页面试题,前前后后不间断的更新了两年,准备换工作时,总是拿来看看,有比较好的面试题,也不间断的更新,面试题目录如下: 【基础】面向对象的特征有哪些方面 13 抽象 13 继承 13 封装 13 多态性 13 【基础】...

    Fundamental-2D-Game-Programming-With-Java:《用Java进行2D游戏编程》一书的源代码示例-java source code

    首先,我们来看Java在2D游戏编程中的应用。Java作为一种跨平台的编程语言,具有丰富的库和工具支持2D图形绘制,例如Java AWT(Abstract Window Toolkit)和Swing库。这些库提供了基本的窗口和组件创建,以及图形绘制...

    UrlReWriteDemo

    【UrlReWriteDemo】是一个基于Java实现的伪静态技术演示项目,旨在帮助开发者理解并掌握如何在实际应用中实现URL重写,以达到优化网站SEO(搜索引擎优化)和提升用户体验的效果。伪静态技术的主要目的是将动态URL...

    FlexUI:FlexUI或(灵活用户界面)是一个旨在将HTML5和CSS图形设计的功能嵌入Java桌面应用程序的项目

    为了更好地理解和使用FlexUI,开发者需要掌握以下几个关键点: 1. HTML5和CSS3基础:理解HTML标签、属性以及CSS选择器、样式规则等基本概念。 2. JavaScript基础:虽然FlexUI主要用Java编写,但JavaScript对于创建...

    1000道 互联网Java工程师面试题 485页

    #### 24、chubby是什么,和zookeeper比你怎么看? - **chubby**:Google的分布式锁服务。 - **比较**:两者都提供了一致性服务,但chubby更专注于锁服务,而Zookeeper提供更广泛的服务。 #### 25、说几个zookeeper...

    PHP基础教程 是一个比较有价值的PHP新手教程!

    看看这个页面你就知道你的PHP安装使用的选项了。 2.3 语法 就像前面提到的一样,你可以混合编写你的PHP代码和HTML代码。因此你必须有办法将两者区别开来。以下就是你可以采用的几种方法。你可以选用其中一种你最...

    人工智能_毕业设计_利用swing做出的扫雷桌面游戏,运行时直接双击可执行文件夹下的“扫雷.exe”即可

    这些功能可能是通过算法实现,比如机器学习或规则引擎,来提升游戏体验。而“游戏”标签则表明这是一个娱乐性质的应用。“java”和“毕业设计”标签再次确认了项目的技术栈和其作为教育背景的实践项目。最后,“扫雷...

    TTS 中文发音源代码

    描述中提到“TTS中文等几国发音源代码,完整的程序在里面”,这意味着提供的压缩包可能包含了不止一种语言的TTS发音源码,而且整个实现应该是完整的,包括了所有必要的组成部分。这通常意味着我们可以期待找到音素...

    FileFlatGeneratJava:生成类 Java

    Java类生成通常涉及到以下几个关键知识点: 1. **模板引擎**:`FileFlatGeneratJava`可能使用了某种模板引擎,如FreeMarker或Velocity,来根据预定义的模板生成Java源代码。模板引擎允许开发者定义好类的结构和模式...

Global site tag (gtag.js) - Google Analytics