RuleGo v0.18.0 发布:Go 轻量级、高性能、嵌入式、可编排组件式规则引擎

RuleGo 是一个基于 Go 语言的轻量级、高性能、嵌入式、可编排组件式的规则引擎。也一个灵活配置和高度定制化的事件处理框架。支持异构系统数据集成,可以对输入消息进行聚合、分发、过滤、转换、丰富和执行各种动作。

典型使用场景

  • 边缘计算: 可以在边缘服务器部署 RuleGo,对数据进行预处理,筛选、聚合或者计算后再上报到云端。数据的处理规则和分发规则可以通过规则链动态配置和修改,而不需要重启系统。
  • 物联网: 收集设备数据上报,经过规则链的规则判断,触发一个或者多个动作,例如:发邮件、发告警、和其他设备或者系统联动。
  • 数据分发: 可以根据不同的消息类型,调用 HTTP、MQTT 或者 gRPC 把数据分发到不同系统。
  • 应用集成:RuleGo 当做胶水连接各种系统或者协议,例如:ssh、webhook、kafka、消息队列、数据库、chatGPT、第三方应用系统。
  • 异构系统数据集中处理: 从不同的数据源(如 MQTT、HTTP、WS、TCP/UDP 等)接收数据,然后对数据进行过滤、格式转换、然后分发到数据库、业务系统或者仪表板。
  • 高度定制化业务: 把高度定制化或者经常变化的业务解耦出来,交给 RuleGo 规则链进行管理。业务需求变化而不需要重启主程序。
  • 复杂业务编排: 把业务封装成自定义组件,通过 RuleGo 编排和驱动这些自定义的组件,业务逻辑并支持动态调整和替换。
  • 微服务编排: 通过 RuleGo 编排和驱动微服务,或者动态调用第三方服务处理业务,并返回结果。
  • 业务代码和业务逻辑解耦: 例如:用户积分计算系统、风控系统。
  • 自动化: 例如:流程自动化系统、营销自动化系统、对接大模型提取用户意图,然后触发规则链与其他系统进行联动或者进行业务处理。
  • 灵活配置和高度定制化的事件处理框架: 对不同的消息类型,进行异步或者同步的处理。

架构图

本次更新

筑牢底座,迎接2024,本次主要增加了:

1.增加AOP(面向切面编程,Aspect Oriented Programming)机制,它类似拦截器或者hook机制,但是功能更加强大和灵活。文档

  • 它允许在不修改规则链或节点的原有逻辑的情况下,对规则链的执行添加额外的行为,或者直接替换原规则链或者节点逻辑。
  • 它允许把一些公共的行为(例如:日志、安全、规则链执行情况跟踪、组件降级、组件重试、组件缓存)从业务逻辑中分离出来。
  • 它允许你更好地控制和扩展RuleGo框架。

2.另外增加生产环境的可靠性验证,增加了大量的单元测试(覆盖率92%)和性能测试测试用例(链接)。

详细更新:

[v0.18.0] 2023/12/27

  • feat:增加AOP模块,它允许在不修改规则链或节点的原有逻辑的情况下,对规则链的执行添加额外的行为,或者直接替换原规则链或者节点逻辑。 提供以下增强点:Before Advice、After Advice、Around Advice、Start Advice、End Advice、Completed Advice、OnCreated Advice、OnReload Advice、OnDestroy Advice。文档
  • feat:restApiCall节点组件,增加SSE(Server-Sent Events)流式请求模式,支持对接大模型接口。
  • feat:增加CI自动化测试流程。
  • feat:增加大量单元测试,覆盖率达到92%。
  • feat:增加性能测试用例 
  • feat:sendEmail节点组件,增加ConnectTimeout配置。
  • feat:/examples/server示例工程,增加 -js -plugins -chain_id flags,支持启动加载js原生文件、插件和指定mqtt订阅处理规则链ID。
  • fix:/examples/server示例工程,规则链文件夹多层路径无法正常解析。
  • fix:/examples/server示例工程,保存规则链,可能会出现旧规则链文件数据无法正确覆盖。
  • fix:metadata可能会出现并发读写问题。
  • fix:规则引擎同步处理数据,有几率无法正确调用onCompleted回调函数。
  • fix:RuleChainPool nil问题。
  • fix:mqtt endpoint,无法通过header得到主题。
  • refactor:onEnd回调函数允许得到relationType。
  • refactor:删除函数Configuration.GetToString。
  • opt:部分组件,增强nil检查。
  • opt:dsl AdditionalInfo字段 增加omitempty json tag。
  • opt:run go fmt。

其他信息

  • 欢迎在 Gitee 或者 Github 上提交反馈或建议
  • 如果喜欢这个项目,请给我们点个Star
  • 文档官网:rulego.cc

猜你喜欢

转载自www.oschina.net/news/272552/rulego-0-18-0-released