2、Drools规则引擎-为什么使用规则引擎

简介: 上文我们说过,规则引擎其实就是将if else全部给抽离出来了。但是这就是我们的规则引擎的全部内容吗?规则放在哪里都是放,为什么一定要拿规则引擎来抽离呢?肯定是规则引擎给我们解决了某些问题。本文主要讲的就是规则引擎是解决什么的方案

echo编辑整理,欢迎转载,转载请声明文章来源。欢迎添加echo微信(微信号:t2421499075) 交流学习。


上文我们说过,规则引擎其实就是将if else全部给抽离出来了。但是这就是我们的规则引擎的全部内容吗?规则放在哪里都是放,为什么一定要拿规则引擎来抽离呢?肯定是规则引擎给我们解决了某些问题。本文主要讲的就是规则引擎是解决什么的方案

为什么使用规则引擎?

  • if else需要抽离不是目的
  • 也不是规则引擎有优秀的编码语法

从实例看问题

真实需求分析:新增用户,在新增用户的时候,根据用户的所在地打标记,比如:某用户是北京的,标记北漂,是广州的,标记广漂,依次类推。第一版需求我们看到的代码可能是这样的

if ("上海".equals(people.getAddress())) {
    people.setFlag("上漂");
    peopleServer.insert(people);
}
if ("北京".equals(people.getAddress())) {
    people.setFlag("北漂");
    peopleServer.insert(people);
}
if ("深圳".equals(people.getAddress())) {
    people.setFlag("深漂");
    peopleServer.insert(people);
}
if ("广州".equals(people.getAddress())) {
    people.setFlag("广漂");
    peopleServer.insert(people);
}
...
  • 感觉这些if else很多我们可以提炼一些公共的地方,同时根据规则,我们可以应用策略模式,或者责任链模式,来优化这样的层级结构。

上面的需求版本迭代:领导发现,某一地区的用户很多,比如:北京,如果说北京新增人员全都用北漂来标记,标记出来的用户将近十几万,这样子不利于数据分析和收益转化,于是乎,在北京这个地域的条件上加了个条件,年龄段,18-30标记‘北漂青年’,30-40,‘北漂实力户’等等。看到的代码可能就变成了这样了

if ("上海".equals(people.getAddress())) {
    people.setFlag("上漂");
    peopleServer.insert(people);
}
if ("北京".equals(people.getAddress())) {
    if (people.getAge() > 18 && people.getAge() <= 30) {
        people.setFlag("北漂青年");
        peopleServer.insert(people);
    }
     if (people.getAge() > 30 && people.getAge() < 40) {
        people.setFlag("北漂实力户");
        peopleServer.insert(people);
    }
     ...
}
if ("深圳".equals(people.getAddress())) {
    people.setFlag("深漂");
    peopleServer.insert(people);
}
if ("广州".equals(people.getAddress())) {
    people.setFlag("广漂");
    peopleServer.insert(people);
}
...
  • 当需求变更只有,我们还能使用策略模式吗?还能使用责任链吗?注意到这里就有了一个很重要的问题,我这实例里面为了突出if else这样的规则,省略了业务代码,但是真实的开发当中,我们一般会在if else里面去写很多的对应的业务代码,根据我们的标记,来给用户推送,同时去编写推送策略和推送短信之类的。那再这样的情况下我们的设计模式就不在实用了。最关键的就是如果实用设计模式,整体的代码架构就失去了灵活性,共性的地方太多,如果规则再次变更,要更改的地方太多。

为什么版本迭代让我们的很多方式优化if else失去了作用?

  • 很多地方不能解决规则和业务分离
  • 多数优化方式都不能直接或间接的灵活分配,很多都是利用共性抽离的
  • 规则迭代的时候,优化部分很容易出现牵一发动全身

规则引擎应用的话,能解决这样的问题吗?

  • 规则引擎最大的作用就是灵活的将规则和业务剥离

总结

规则引擎,解决了灵活变更规则不影响具体业务的难点

目录
相关文章
|
运维 JavaScript Java
govaluate 规则引擎
govaluate 规则引擎
2338 0
govaluate 规则引擎
|
Java
规则引擎选型及应用
规则引擎具体执行可以分为接受数据输入,解释业务规则,根据业务规则做出业务决策几个过程。 使用规则引擎可以把复杂、冗余的业务规则同整个支撑系统分离开,做到架构的可复用移植。
24072 0
|
6月前
|
数据可视化 Java
探索Drools:Java世界的规则引擎
探索Drools:Java世界的规则引擎
396 1
|
算法 Java
3、Drools规则引擎-为什么选择Drools
Drools 是用 Java 语言编写的具有一个易于访问企业策略、易于调整以及易于管理的开源业务规则引擎 ,其基于CHARLES FORGY’S的RETE算法 符合业内标准,速度快且效率高。 业务分析师人员或审核人员可以利用它轻松查看业务规则, 检验已编码的规则执行了所需的业务规则。
273 0
|
算法 Java JavaScript
规则引擎
我是阿里巴巴做规则引擎相关工作多年的java工程师一枚,本职工作就是通过规则引擎、规则管理平台等技术输出,来应对阿里巴巴复杂多变的上层规则相关业务的支持。限于技术保密、安全等因素,本文只讲一些个人对“规则引擎”的看法,欢迎大家一起探讨。
26029 1
|
存储 SQL Java
规则引擎深度对比,LiteFlow vs Drools! 下
规则引擎深度对比,LiteFlow vs Drools! 下
|
存储 消息中间件 JavaScript
规则引擎深度对比,LiteFlow vs Drools! 上
规则引擎深度对比,LiteFlow vs Drools! 上
1、Drools规则引擎-什么是规则引擎
### 什么是规则引擎 规则引擎由推理引擎发展而来,是一种嵌入在应用程序中的组件, 实现了将业务决策从应用程序代码中分离出来,并使用预定义的语义模块编写业务决策。 接受数据输入,解释业务规则,并根据业务规则做出业务决策。
546 0
1、Drools规则引擎-什么是规则引擎
|
Java Spring
4、Drools规则引擎-Drools入门案例
Drools的实现并不难,关键是了解他的语法即可
292 0
4、Drools规则引擎-Drools入门案例
|
存储 SQL 监控
规则引擎 | 学习笔记
快速学习 规则引擎
1431 0
规则引擎 | 学习笔记