决策引擎平台建设方案

news/2024/11/23 9:53:18/

文档修订历史

时间版本主要内容
2023.05.12v1.0.0初始化

1. 概述

1.1 需求

1.1.1 需求背景

   当同一个业务场景中,有非常多的业务分支后,需要有非常多的 if 判断,来承载这些简单的业务逻辑,但随着业务的发展,业务逐渐复杂,if 分支越来越多,可维护性越来越差,技术债务越来越重。
   if-else 的目的,不外乎以下若干场景:

  1. 异常逻辑处理
  2. 特殊case
  3. 不同业务流程处理
  4. … …

   但这些分支逻辑难以避免,我们需要考虑如何正视它。

1.1.2 需求目标

   业务规则往往是一个庞大且不断变化的规则组合,这使得系统非常复杂,如果只是使用常规代码,则会产生大量的维护工作。

   我们使用规则引擎,将庞大的规则组合,从业务代码中抽离出来维护到一个数据源中,实现 将业务流程与业务规则分离 的目标。
在这里插入图片描述

专题分析

规则引擎方案调研

方案详情优点缺点
Drools开源规则引擎,由Red Hat开发和维护。它提供了一个成熟的规则引擎和规则管理系统,支持规则的动态定义、评估和执行。1. 功能丰富 2. 支持DB存储规则1. 复杂度高,学习成本高
EasyRule轻量级框架,基本上只提供了一个规则判断和行为执行的框架。通过一些注解实现抽象的方式去做规则。学习成本低1.不包含规则编排等功能 2. 不提供连接DB的能力,修改配置后不实时生效

Drools

Drools常用 API 使用介绍

EasyRule

EasyRule常用API
EasyRule-github-代码用例

EasyRule 使用介绍

   主要涉及的模型如下:

  • Rule:规则的生成
    • 多种方式来定义规则
  • Condition:执行条件的定义
  • Action: 条件满足后的行为
  • RuleEngine:执行决策的引擎

Rule的生成方式

  1. 注解方式
@Rule(name = "my rule1", description = "my rule description", priority = 1)
public class MyRule1 {@Conditionpublic boolean when(@Fact("type") Integer type) {return type == 1;}@Action(order = 1)public void execute1(Facts facts) throws Exception {log.info("MyRule1 execute1, facts={}", facts);}@Action(order = 2)public void execute2(Facts facts) throws Exception {log.info("MyRule1 execute2, facts={}", facts);}
}
  1. 流式API
Rule weatherRule = new RuleBuilder().name("weather rule").description("if it rains then take an umbrella").when(facts -> facts.get("rain").equals(true)).then(facts -> System.out.println("It rains, take an umbrella!")).build();
  1. 表达式方式
    支持 MVEL , SpEL and JEXL
Rule weatherRule = new MVELRule().name("weather rule").description("if it rains then take an umbrella").when("rain == true").then("System.out.println(\"It rains, take an umbrella!\");");
  1. 规则描述文件
---
name: adult rule
description: when age is greater than 18, then mark as adult
priority: 1
condition: "person.age > 18"
actions:- "person.setAdult(true);"
---
name: weather rule
description: when it rains, then take an umbrella
priority: 2
condition: "rain == true"
actions:- "System.out.println(\"It rains, take an umbrella!\");"

思考与方案改进

  1. 决策引擎是否可以将决策配置转移到 DB 中,每次配置调整后,可以实时生效?
  2. API中,是否可以按不同的业务,传入一个业务唯一id(如决策码),决策出一个boolean或决策出一个String内容,简化业务接入放的使用?

http://www.ppmy.cn/news/68570.html

相关文章

【vcpkg】像Python一样方便的import 自己的c++库

介绍vcpkg的背景 什么是vcpkg vcpkg是一个开源的C库管理工具,它可以帮助开发者在Windows、Linux和macOS等操作系统上快速安装和管理C库。vcpkg支持超过1500个C库,包括Boost、OpenSSL、SDL2等常用库。 vcpkg的历史和发展 vcpkg最初由微软开发&#xf…

Redis持久化:RDB和AOF(版本redis 7.0)

什么是持久化? 学过计算机基础的都知道以一种磁盘,只要关机,那么磁盘的内容都会被清空,这种磁盘称为内存,而Redis则是一种内存数据库,redis中的数据也都存储在磁盘中,如果服务器中进程被关掉&am…

navicat连接oracle报错 ORA-28547

报错 原因 Navicat自带的oci.dll并不支持oracle11g 具体操作 1. 先用idea连接oracle,查看oracle版本 select * from v$version; 2. 去官网下载 Instant Client 地址: Oracle Instant Client Downloads 下载 选择对应的版本(下载时&#x…

MySQL高级语句(一)

一、SQL高级语句 1、 SELECT 显示表格中一个或数个栏位的所有资料 语法:SELECT "字段" FROM "表名"; select * from test1; select name from test1; select name,sex from test1;2、DISTINCT 不显示重复的内容 语法:SELECT D…

Xilinx FPGA DDR3设计(三)DDR3 IP核详解及读写测试

引言:本文我们介绍下Xilinx DDR3 IP核的重要架构、IP核信号管脚定义、读写操作时序、IP核详细配置以及简单的读写测试。 01.DDR3 IP核概述 7系列FPGA DDR接口解决方案如图1所示。 图1、7系列FPGA DDR3解决方案 1.1 用户FPGA逻辑(User FPGA Logic&#…

二叉搜索树、AVL树、红黑树底层源码以及迭代器模拟实现,map/set的封装

这次给大家分享的还是关于二叉树部分的内容,之前的文章已经分享过一些二叉树的基础知识,如果不了解的朋友可以看看:二叉树以及堆和堆排序。普通的二叉树其实是没有什么实际的应用价值的,而map和set大家用过或者听过吗?…

外贸人如何精准开发客户?Facebook开发客户全攻略

现在做跨境的都了解的一个社媒平台就是Facebook了,因为很多人都会拿Facebook来开发客户,忙里偷闲,今天东哥就来聊聊用Facebook开发客户的一些心得。 用Facebook开发客户的心得 1、利用关键词搜索 使用行业相关的关键词、产品特定的关键词、相…

通俗理解git和github是什么,30分钟速通版

文章目录 安装 git配置 git第一个 git 仓库git 基本功能 / 本地仓库add 修改跟踪文件并放入暂存区commit 提交暂存区,产生新版本status 查看文件的修改和暂存状态diff 查看已修改而未进入暂存区的文件状态log 查看过去的提交日志 git 远程仓库remote 链接远程仓库pu…