规则引擎分析

【面临问题】

业务规则、商业逻辑复杂

业务规则异常调整,如折扣、价格

24小时不停机,实时修改规则

【解决问题】

声明式编程,关注“做什么”,而不是“怎么做”

逻辑、数据分离

rete算法

算法转规则,业务规则太复杂没有现成的算法实现

【What】

嵌入式组件,业务决策与系统分离

核心获取knowledge

应用knowledege到fact

conditions(LHS)和actions(RHS)

正向链 或 反向链

推理引擎

rules(规则库)-> engine <-fact (working memory) (rete算法)

{正向链}

RULE ->parse rule->RuleBase (fire)-> Agenda(activation(rule-fact))

| (create)

FACT ->assert facts -> working memory (rule-fact)

【drools】

JAVA & RETE算法实现

2001 ,线程蛮力搜索

2.0 , 基于rete算法重写

3.0 , drl文件,特定的dsl专门针对规则编写

5.0 ,drools func, flow rule

格式:drl,dsl,excel,xml

环境:droolsjbpm-tools 安装到eclipse插件

eclipse设置运行时环境drools-runtime

问题域构建

{规则语言}

基础

POJO即fact,规则、业务系统对接的桥梁

fact插入workmemory后,返回FactHandle,是插入workmemory的句柄

imports 需要导入的类

global 比如service、对象等workmemory需要使用的

关键字duration,推迟多长时间之后,启动另一个线程来执行actions

关键字activation-group,多个rule定义为一个group,那么只有一个会被执行

关键字agenda-group,代码中必须显式设置focus,那么这个规则才会被执行

关键字function,在drl中定义动态脚本函数

关键字query,在drl中定义查询函数,通过传参查询,规则校验,返回结果

流程:指定drl,builder编译,打包成package,包来创建会话,fact放进会话,规则匹配,dispose释放

{RETE算法}

RETE拉丁语网络,将规则组织成网络,在内存中进行快速匹配

RETE节点:root节点,所有对象进入网络的入口,objecttyperoot,进入对象类型检查,引擎只接受object类型的对象进入;Alpha节点,用来评估字面条件,条件会被连接到一起;beta节点,左右两个输入,joinnode,notnode

规则树,空间换时间,节省效率

转载于:https://my.oschina.net/jsycwangwei/blog/1492811

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值