规则引擎的定义及体系结构

规规则引擎的定义及其体系结构

摘 要

随着经济的迅速发展,市场的快速变化导致商业业务规则的变化也越来越快,因此对于企业的IT 部门或者IT 企业来说,这就要求设计出来的应用系统能够适应这种快速变化。然而,软件的开发周期和维护周期长,这和适应快速变化的市场需求产生了矛盾。规则引擎的出现很好的解决了这一矛盾。有了规则引擎,我们可将以程序代码的形式固化在应用系统中的业务逻辑分离、抽象出来,被分离的业务逻辑以业务规则形式存储在规则库中,并通过规则引擎进行执行。

本文将介绍规则引擎的定义,并将以WebSphere ILOG JRules 规则引擎为例介绍其体系结构。

关键字 规则引擎 业务规则 业务对象模型 规则执行模型 规则调用

目 录

第1章 绪论

1.1 规则引擎的产生背景

第2章 规则引擎概述

2.1 业务规则

2.2 规则引擎

2.2.1 什么是规则引擎

2.2.2 使用规则引擎的优点

2.3 规则引擎运行模式

第3章 规则引擎的架构和工作机制

3.1 规则引擎的架构原理

3.2 规则引擎的工作机制

第4章 总结

第1章 绪论

1.1 规则引擎的产生背景

随着信息技术在企业的广泛的应用,企业 IT 部门所开发和维护的应用系统也越来越复杂,而现代企业要求响应快速及灵活,他们对企业软件也有同样的要求。企业管理者对企业级IT 系统的开发有着如下的要求:一、为提高效率,管理流程必须自动化,即使现代商业规则异常复杂。二、市场要求业务规则经常变化,IT 系统必须依据业务规则的变化快速、低成本的更新。三、为了快速、低成本的更新,业务人员应能直接管理IT 系统中的规则,不需要程序开发人员参与。因此如何使应用系统能够更快的响应的企业业务的变化已成为企业 IT 发展的重要挑战之一。

另外,项目开发人员会碰到了以下问题:一、程序=算法+数据结构,有些复杂的商业规则很难推导出算法和抽象出数据模型。二、软件工程要求从需求—>设计—>编码,然而业务规则常常在需求阶段可能还没有明确,在设计和编码后还在变化,业务规则往往嵌在系统各处代码中。三、对程序员来说,系统已经维护、更新困难,更不可能让业务人员来管理。 但是,当包含业务逻辑的代码隐藏在大量其他代码中时,修改就变得缓慢、痛苦且易出错了。因此,复杂企业级项目的开发以及其中随外部条件不断变化的业务规则, 迫切需要分离商业决策者的商业决策逻辑和应用开发者的技术决策,并把这些商业决策放在中心数据库或其他统一的地方,让它们能在运行时(即商务时间)可以动态地管理和修改从而提供软件系统的柔性和适应性。规则引擎正是应用于上述动态环境中的一种解决方法。

第2章 规则引擎概述

2.1 业务规则

业务规则专家组 (BRG)规定了业务规则的两个定义。第一个定义与业务观点相关,而第二个定义与IT 相关:

1、“从业务的角度而言,业务规则是一种原则,包含在特定活动或范围内关于指导、操作、实践或过程的行为规范。”

2、“从IT 角度而言,规则是可集成到现有基础结构(如基于应用程序或面向服务的体系结构)的决策系统的灵活实现。”

一个业务规则包含一组条件和在此条件下执行的操作,它们表示业务规则应用程序的一段业务逻辑。业务规则通常应该由业务分析人员和策略管理者开发和修改,但有些复杂的业务规则也可以由技术人员使用面向对象的技术语言或脚本来定制。业务规则的理论基础是:设置一个或多个条件,当满足这些条件时会触发一个或多个操作。

运行时,规则引擎必须对这些业务规则进行解释。可以将规则引擎理解为一种高性能的专用解释程序,其中包含if-then 命令,可根据预先定义的规则对转换的值和对象进行分析,然后返回修改后的值和对象,或直接执行操作。

2.2 规则引擎

2.2.1 什么是规则引擎

规则引擎由推理引擎发展而来,是一种嵌入在应用程序中的组件,实现了将业务决策从应用程序代码中分离出来,并使用预定义的语义模块编写业务决策。接受数据输入,解释业务规则,并根据业务规则做出业务决策。其中,推理引擎由三部分组成,它们分别是规则解释器—Rule Interprete、模式匹配器—Pattern Matcher和议程—Agenda 。模式匹配器从规则库中找出需要执行的规则并写入议程;议程为这些规则赋予优先级,确定执行顺序;规则解释器执行这些规则并输出运行结果。

规则引擎具有以下功能:

1、能够将关键的业务规则与其他源代码分开保存。它使用户能够迅速实施业务逻辑的更改而不必重新编写应用程序。

2、它使用了XOM ,即定义应用执行规则的类。这些类可以有不同的数据来源,这些数据可以在XOM 中像对Java 类一样进行查看和处理。例如,XOM 使用了功能强大的XML 绑定系统,使规则引擎能够直接对XML 数据或Web Service所提供的数据进行操作。

3、通过嵌入方式,可以在任何Java 应用程序中执行业务规则,并支持多种部署方案,从而优化了系统性能和扩展性。

2.2.2 使用规则引擎的优点

使用规则引擎可以通过降低实现复杂业务逻辑的组件的复杂性,降低应用程序的维护和可扩展性成本,其优点如下:

1、分离商业决策者的商业决策逻辑和应用开发者的技术决策;

2、能有效的提高实现复杂逻辑的代码的可维护性;

3、在开发期间或部署后修复代码缺陷;

4、应付特殊状况,即客户一开始没有提到要将业务逻辑考虑在内;

5、符合组织对敏捷或迭代开发过程的使用;

2.3 规则引擎的运行模式

规则引擎根据规则的不同应用场景和业务规则的特点提供了三种常用的不同的运行模式:RetePlus 、Sequential 和 FastPath 。下面将以当前最主流的规则引擎JRules ILog 为例介绍这三种运行模式。

RetePlus

Rete 是目前主流的规则引擎模式匹配算法,RetePlus 则是 JRules 在 Rete 算法上的扩展和优化,也是 JRules 规则引擎默认的运行模式。RetePlus 运行模式为 ILOG 规则引擎提供了种种手段,用以尽量减少需要加以评估的规则和条件的数量,计算哪些规则应当执行,并确定这些规则的执行顺序。在 RetePlus 算法中,规则引擎使用 Working memory (工作内存) 和 Agenda 来存放和操作应用程序对象。Working memory 中包含的应用程序对象的引用,Agenda 则按顺序列出将要执行的规则实例。如图1所示:

图 1. RetePlus 执行模式

具体执行过程如下:

1、规则引擎依据 Working Memory 中的数据对象来匹配规则集中规则的条件部分。在模式匹配过程中,RetePlus 首先创建出以规则条件测试之间的语义关系为基础的网络(步

骤 1),然后将匹配的规则实例化并添加到 Agenda 中,随后对 Agenda 中的规则按照一定原则进行排序(步骤2)。

2、执行 Agenda 中的规则实例,即执行规则的动作(Action )部分。同时,规则实例的执行也会影响 Working Memory 中的数据对象,主要方式有:(步骤3):

(1)往 Working Memory 中加入一个新的对象

(2)移除 Working Memory 中现有对象

(3)修改现有对象的属性

3、以上过程将不断重复,直至执行完 Agenda 中所有规则实例。

在RetePlus 算法中每当 Working Memory 被修改,规则引擎将重复模式匹配的过程。它在每次规则执行数据修改后重新评估每个规则匹配。这可能会改变 Agenda 中的规则实例。因此,RetePlus 是渐进的和数据驱动的。这些特点使 RetePlus 在计算和关联性类型的应用方面拥有卓越的性能。

Sequential

顺序运行模式,顾名思义,即规则引擎按顺序执行 rule task 中符合条件的所有规则。如图 2 所示:

图 2. 顺序执行模式

具体执行过程如下:

1、规则引擎根据输入参数以及 working memory 中的对象集合和规则的条件部分进行匹配。每次匹配都将生成一个规则实例并立即运行。(步骤 1)

2、当规则实例被执行后,它有可能设置属性或规则集输出参数的值。(步骤 2)

顺序算法执行的规则是无状态的。顺序算法的运行就像堆栈一样,匹配的规则只会运行一次,而不会再次评估。因此在顺序模式下,规则中不能使用类似“至少有一 个 ”、“如下对象的数目:”等等跟 working memory 中对象有关系的存在性条件(existence conditions),除非这个对象是集合类型。顺序模式的特性决定了其在校验和一致性等类型的应用中有良好的性能表现。

FastPath

Fastpath 运行模式是增强型的顺序运行模式,和顺序模式类似,Fastpath 也是顺序运行,但是它同时还能和 RetePlus 模式一样在进行模式匹配时检测规则条件的语义关系。如图 3

所示:

具体执行过程如下: 图 3.FastPath 执行模式

1、在 Fastpath 模式中,规则引擎可以通过 working memory 引用应用数据对象或规则集参数。与 Reteplus 类似,在模式匹配时 Fastpath 同样创建以规则条件测试之间的语义关系为基础的网络(步骤 1)。

2、每次匹配,将创建一个规则实例并立即执行。规则实例执行后,它可能修改 working memory 中的对象,但是这些修改不会影响其它规则的执行,并且规则引擎也不会重复模式匹配的过程(步骤 2)。

Fastpath 综合了 Reteplus 的模式匹配和顺序运行模式的规则执行的特性,从这个意义上来说,它在关联型应用和校验类应用中都有较好表现。和顺序运行模式一样,Fastpath 运行模式也是无状态的,适合在大量单独执行简单判定或少量交叉测试的规则上进行对象匹配。这样一些规则集可以在没有任何 agenda 支持下很好的按顺序执行。除了作为一种变异的顺序模式的优势,Fastpath 运行模式的目的是进一步优化一致性和校验性类型规则的执行,通常这些类型的规则占据了商业规则的绝大部分。

第3章 规则引擎的体系结构

3.1 规则引擎的架构原理

1、规则引擎的架构如图4所示:

图4. 业务规则引擎架构

2、规则引擎的推理步骤如下:

(1)将初始数据(fact )输入至工作内存(Working Memory)。

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

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

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

(5)执行Agenda 中的规则。重复步骤(2)至(5),直到执行完毕Agenda 中的所有规则。

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

3.2 规则引擎的工作机制

规则引擎是一种根据规则中包含的指定过滤条件,判断其能否匹配运行时刻的实时条件来执行规则中所规定的动作的引擎。为更好的理解并阐述规则引擎的工作机制,下面先介绍四个与规则引擎相关的基本概念。

1、信息元(Information Unit)

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

2、信息服务(Information Services)

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

3、规则集(Rule Set)

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

4、队列管理器(Queue Manager)

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

下面介绍规则引擎的工作机制。

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

由规则引擎的工作机制可以看出,任何一个规则引擎都需要很好地解决规则的推理机制和规则的条件匹配的效率问题。当引擎执行时,引擎会根据规则执行队列中的先后顺序逐条执行规则实例。出于规则的行为部分可能会导致工作区中的数据对象改变,从而会是执行队列中的某些规则实例因为条件改变而失效,必须从队列中撤销;有可能会激活原来不满足条件的规则,生成新的规则实例进入执行队列。于是就产生了一种“动态”的规则执行链,形成规则的推理机制。这种规则的“链式”反应完全是由工作区中的数据驱动的。

第4章 总结

当今世界经济的快速变化,要求企业具有高度的适应性来紧跟这种快速变化,才能在当今竞争激烈的经济环境中生存下去。这就要求作为企业重要组成部分的IT 系统同样具备这样的适应性,来帮助企业捕捉市场机会。然而,软件的开发周期和维护周期都很长,这就和适应当前快速变化的市场产生了矛盾。解决这个矛盾的一个方法就是使这些快速变化的商业逻辑能够从应用程序系统中分离出来。基于规则的专家系统的出现给开发人员以解决这个矛盾的契机。规则引擎由基于规则的专家系统中的推理引擎发展而来的,是一种嵌入在应用程序中的组件,实现了将业务决策从应用程序代码中分离出来,并使用预定义的语义模块编写业务规则。这种分离策略使应用程序在不增加成本的情况下能更好的适应快速变化的市场。 本文主要对规则引擎的定义、运行模式、架构和工作机制等进行了论述,也是对接触规则引擎以来的一次总结。


相关文章

  • 普元工作流软件技术方案建议书_渠道管理
  • 普元工作流软件技术方案 建议书 目 录 1 综述 ............................................................................................................................. ...

  • 自适应Web服务管理框架设计与实现
  • 第41卷第10期浙江大学学报(工学版) VoI_41NolO2007年10月 JournalofZh自iangUniversity(EngineeringScience 0ct.2007 自适应Web服务管理框架设计与实现 韩 冬,王颖,朱 岩 (北京航空航天大学计算机学院,北京100083) 摘要 ...

  • 按需业务流程生命周期,第 1 部分: 为您的按需业务流程构建基础
  • 系列概述 文档选项 将此页作为电子邮件发送 未显示需要 JavaScript 的文档选项 拓展 Tomcat 应用 下载 IBM 开源 J2EE 应用服务器 WAS CE 新版本 V1.1 级别: 初级 German Goldszmidt,PhD, 资深软件工程师, IBM Joshy Joseph ...

  • 网络安全事件综合关联分析--解决方案
  • 网络安全事件管理的综合关联分析解决方案★ 刘雪娇肖德宝常亚楠陈历淼 华中师范大学计算机科学系430079 摘要:随着网络的飞速发展以及信息化程度的逐步提高,信息安全威胁呈现出多元化.复杂化的趋势,人们不断地采用防火墙.入侵检测.漏洞扫描等各种安全设备来监控网络以抵御入侵.然而,这些设备的广泛应用产生 ...

  • 电子税务局毕业论文
  • 学校编码:10384 分类号 密级 学号:X[1**********] UDC 工 程 硕 士 学 位 论 文 某市税收数据综合应用平台 数据质量监控系统的设计与实现 Design and Implementation of Data Quality Monitoring system for In ...

  • 事故车定义
  • 根据车辆发生严重事故经修复后对车辆整体安全性.耐久性和功能性的影响程度进行判别,事故车定义为因严重撞击或者水泡.火烧即使经修复后的车辆. 泡水车定义: 车辆曾经泡在水里,水位超过引擎盖,水曾经进入驾驶室,且水面覆盖至驾驶室内地板以上位置 火烧车定义: 车辆的车身承载式框架部件(见以下图表)存在有明火 ...

  • 网络营销与网站推广课程设计报告1
  • ian沈阳航空航天大学北方科技学院 课程设计说明书 课程名称: 网络营销与网站推广实践 学 生 姓 名 专 业 信管(电子商务) 班 级 B743211班 学 号 B74321118 指 导 教 师 孟繁宇 马丽娜 成 绩 沈阳航空航天大学北方科技学院 课 程 设 计 任 务 书 课程设计名称 网络 ...

  • 大学信息技术基础基本完整复习大纲
  • 复习大纲 1. 信息的定义.特点 自然界和一切人类活动所传达出来的信号和消息,是事物表现的这一种普遍形式.本质上说,信息是事物自身(显示其存在方式或运动状态)的属性,是客观的现象 客观性:信息是客观存在的,不以人的意志为转移. 传递性:信息的获取依赖于传递. 时效性:信息从产生.出发.接收到进入利用 ...

  • Activiti工作流数据库表结构
  • Activiti 数据表结构 目录 1 ACTIVITI 数据库表结构 ----------------------------------------------------------------------------------------------- 2 1.1 数据库表名说明 ---- ...

  • 数据挖掘技术的方法和最新进展
  • 数据挖掘技术的方法和最新进展 李敬社1, 2, 张小木2, 黄泽贵3 (11西安电子科技大学智能信号处理研究所 陕西西安 710071; 21空军工程大学文理学院 陕西西安 710068 31空军工程大学导弹学院 陕西三原 713800) 摘 要:随着大型数据库的不断涌现, 不缺数据缺知识的矛盾日益 ...

© 2024 范文中心 | 联系我们 webmaster# onjobs.com.cn