BizTalk Rule Engine

BRE

规则引擎:

描述业务逻辑的声明

IF

<Condition(s)>

Then

<Action(s)>

策略:

一组相关的规则可以组合成一个策略

基本原理:

1.正向推导(forward-chaining),基于指定策略内的所有规则来推导结论的推导引擎.

2.检查引擎当前状态变量,即所有事实(fact),找出与这些事实相匹配的规则

3.利用事实来评估规则条件

4.如果某规则条件符合,结论就会被执行

5.如果结论执行时会添加或更新事实,整个匹配和评估过程会再重新来一次

为什么需要规则引擎:

1.使用代码实现业务逻辑的传统方法的缺点:

(1).复杂的业务逻辑难以用代码来表达

(2).业务逻辑转换成代码后可理解性下降.

(3).无法应对灵活多变的业务规则

(4).熟悉业务逻辑的是业务分析员而不是程序员.

2.业务规则引擎的优势:

(1).使用推理引擎解释规则声明,不需要人为编码.

(2).声明可以由业务分析人员来维护.

(3).不需要重新编译或部署

(4).真正易变的是条件而不是流程

策略的版本管理

1.策略可以随时取消部署

2.多个版本可以同时部署,永远使用最近publish的策略.

BizTalk业务规则相关概念

Term

Description

Policy 策略

逻辑上相关的一组规则

Rule 规则

包含条件组合,及当条件组合为真时执行的一组动作

Condition 条件

包含对事实的判断

Facts 事实

条件和动作所操作的对象

Actions 动作

当条件为真时所执行的操作

Vocabulary 词汇

逻辑上相关的一组定义

Definition 定义

对技术数据定义的用户友好的描述

Rule Engine
规则引擎

根据事实评估相应的条件并执行相应的操作

Rule based application

提交事实并调用策略

Rule Store
规则库

保存策略和规则的仓库

Fact事实类型

1.XML

(1).XmlDocument的包装,提供了规则处理中需要的内部数据

(2).通过XPath来定位元素结点来取得数据

(3).流程内的消息变量本身就是XmlDocument,因此可以直接作为事实传人

2.数据库

(1).在规则中使用数据库事实可以让引擎自动建立更有效率的SQL语句来获取或更新数据库内的数据

(2).引擎会对事实中所有的数据列进行评估

(3).如果是只读数据,最好使用长期事实来实现快取

3..NET类型

(1).任何.NET 类型均可作为事实使用

不需要实现接口或者继承其他基类

(2).组件必须部署到GAC中

 

长期事实和短期事实

1.短期事实会在规则执行是被带入

规则执行过后事实对象会被销毁

2.长期事实可被快取

通过給策略配置.NET 事实获取器

每次执行时调用IFactRetriever.UpdateFacts

以执行引擎实例为单位快取

允许FactRetriever对象将事实快取

 

词汇(Vocabularies)

如何调用业务规则

1.在业务流程中使用调用业务规则Shape

必须包含在Atomic Scope 中

2.在表达式Shape(Expression)中

可以指定要调用的版本

3.可以从.NET程序代码中调用

规则引擎以.NET类别的形式对外服务

允许流程及其他应用程序使用相同的规则

你可能感兴趣的:(Engine)