2022年Java规则引擎工作原理及其应用 .pdf
《2022年Java规则引擎工作原理及其应用 .pdf》由会员分享,可在线阅读,更多相关《2022年Java规则引擎工作原理及其应用 .pdf(7页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、Java 规则引擎工作原理及其应用作者:缴明洋谭庆平出处:计算机与信息技术责任编辑:方舟 2006-04-06 08:18 Java 规则引擎是一种嵌入在Java 程序中的组件,它的任务是把当前提交给引擎的 Java 数据对象与加载在引擎中的业务规则进行测试和比对摘 要 Java 规则引擎是一种嵌入在Java 程序中的组件,它的任务是把当前提交给引擎的 Java 数据对象与加载在引擎中的业务规则进行测试和比对,激活那些符合当前数据状态下的业务规则,根据业务规则中声明的执行逻辑,触发应用程序中对应的操作。引言目前,Java 社区推动并发展了一种引人注目的新技术Java 规则引擎(Rule Eng
2、ine)。利用它就可以在应用系统中分离商业决策者的商业决策逻辑和应用开发者的技术决策,并把这些商业决策放在中心数据库或其他统一的地方,让它们能在运行时可以动态地管理和修改,从而为企业保持灵活性和竞争力提供有效的技术支持。规则引擎的原理1、基于规则的专家系统(RBES)简介Java 规则引擎起源于基于规则的专家系统,而基于规则的专家系统又是专家系统的其中一个分支。专家系统属于人工智能的范畴,它模仿人类的推理方式,使用试探性的方法进行推理,并使用人类能理解的术语解释和证明它的推理结论。为了更深入地了解Java 规则引擎,下面简要地介绍基于规则的专家系统。RBES 包括三部分:Rule Base(k
3、nowledge base)、Working Memory(fact base)和 Inference Engine。它们的结构如下系统所示:图 1 基于规则的专家系统构成如图 1 所示,推理引擎包括三部分:模式匹配器(Pattern Matcher)、议程(Agenda)和执行引擎(Execution Engine)。推理引擎通过决定哪些规则满足事实或目标,并授予规则优先级,满足事实或目标的规则被加入议程。模式名师资料总结-精品资料欢迎下载-名师精心整理-第 1 页,共 7 页 -匹配器决定选择执行哪个规则,何时执行规则;议程管理模式匹配器挑选出来的规则的执行次序;执行引擎负责执行规则和其他
4、动作。和人类的思维相对应,推理引擎存在两者推理方式:演绎法(Forward-Chaining)和归纳法(Backward-Chaining)。演绎法从一个初始的事实出发,不断地应用规则得出结论(或执行指定的动作)。而归纳法则是根据假设,不断地寻找符合假设的事实。Rete 算法是目前效率最高的一个Forward-Chaining推理算法,许多 Java 规则引擎都是基于Rete 算法来进行推理计算的。推理引擎的推理步骤如下:(1)将初始数据(fact)输入 Working Memory。(2)使用 Pattern Matcher比较规则库(rule base)中的规则(rule)和数据(fact
5、)。(3)如果执行规则存在冲突(conflict),即同时激活了多个规则,将冲突的规则放入冲突集合。(4)解决冲突,将激活的规则按顺序放入Agenda。(5)使用执行引擎执行Agenda 中的规则。重复步骤 2 至 5,直到执行完毕所有 Agenda 中的规则。上述即是规则引擎的原始架构,Java 规则引擎就是从这一原始架构演变而来的。2、规则引擎相关构件规则引擎是一种根据规则中包含的指定过滤条件,判断其能否匹配运行时刻的实时条件来执行规则中所规定的动作的引擎。与规则引擎相关的有四个基本概念,为更好地理解规则引擎的工作原理,下面将对这些概念进行逐一介绍。1)信息元(Information Un
6、it)信息元是规则引擎的基本建筑块,它是一个包含了特定事件的所有信息的对象。这些信息包括:消息、产生事件的应用程序标识、事件产生事件、信息元类型、相关规则集、通用方法、通用属性以及一些系统相关信息等等。2)信息服务(Information Services)信息服务产生信息元对象。每个信息服务产生它自己类型相对应的信息元对象。即特定信息服务根据信息元所产生每个信息元对象有相同的格式,但可以有名师资料总结-精品资料欢迎下载-名师精心整理-第 2 页,共 7 页 -不同的属性和规则集。需要注意的是,在一台机器上可以运行许多不同的信息服务,还可以运行同一信息服务的不同实例。但无论如何,每个信息服务只
7、产生它自己类型相对应的信息元。3)规则集(Rule Set)顾名思义,规则集就是许多规则的集合。每条规则包含一个条件过滤器和多个动作。一个条件过滤器可以包含多个过滤条件。条件过滤器是多个布尔表达式的组合,其组合结果仍然是一个布尔类型的。在程序运行时,动作将会在条件过滤器值为真的情况下执行。除了一般的执行动作,还有三类比较特别的动作,它们分别是:放弃动作(Discard Action)、包含动作(Include Action)和使信息元对象内容持久化的动作。前两种动作类型的区别将在2.3 规则引擎工作机制小节介绍。4)队列管理器(Queue Manager)队列管理器用来管理来自不同信息服务的信
8、息元对象的队列。下面将研究规则引擎的这些相关构件是如何协同工作的。如图 2 所示,处理过程分为四个阶段进行:信息服务接受事件并将其转化为信息元,然后这些信息元被传给队列管理器,最后规则引擎接收这些信息元并应用它们自身携带的规则加以执行,直到队列管理器中不再有信息元。图 2 处理过程协作图3、规则引擎的工作机制下面专门研究规则引擎的内部处理过程。如图 3 所示,规则引擎从队列管理器中依次接收信息元,然后依规则的定义顺序检查信息元所带规则集中的规则。如图所示,规则引擎检查第一个规则并对其条件过滤器求值,如果值为假,所有名师资料总结-精品资料欢迎下载-名师精心整理-第 3 页,共 7 页 -与此规则
9、相关的动作皆被忽略并继续执行下一条规则。如果第二条规则的过滤器值为真,所有与此规则相关的动作皆依定义顺序执行,执行完毕继续下一条规则。该信息元中的所有规则执行完毕后,信息元将被销毁,然后从队列管理器接收下一个信息元。在这个过程中并未考虑两个特殊动作:放弃动作(Discard Action)和包含动作(Include Action)。放弃动作如果被执行,将会跳过其所在信息元中接下来的所有规则,并销毁所在信息元,规则引擎继续接收队列管理器中的下一个信息元。包含动作其实就是动作中包含其它现存规则集的动作。包含动作如果被执行,规则引擎将暂停并进入被包含的规则集,执行完毕后,规则引擎还会返回原来暂停的地
10、方继续执行。这一过程将递归进行。图 3 规则引擎工作机制Java 规则引擎的工作机制与上述规则引擎机制十分类似,只不过对上述概念进行了重新包装组合。Java 规则引擎对提交给引擎的Java 数据对象进行检索,根据这些对象的当前属性值和它们之间的关系,从加载到引擎的规则集中发现符合条件的规则,创建这些规则的执行实例。这些实例将在引擎接到执行指令时、依照某种优先序依次执行。一般来讲,Java 规则引擎内部由下面几个部分构成:工作内存(Working Memory)即工作区,用于存放被引擎引用的数据对象集合;规则执行队列,用于存放被激活的规则执行实例;静态规则区,用于存放所有被加载的业务规则,这些规
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 2022年Java规则引擎工作原理及其应用 2022 Java 规则 引擎 工作 原理 及其 应用
限制150内