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


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

典型使用场景

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

本次更新

[v0.17.0] 2023/11/27

  • feat:增加websocket endpoint组件 文档
  • feat:增加tcp/udp endpoint组件 文档
  • feat:增加kafka endpoint组件(扩展组件库) 文档
  • feat:增加tcp/udp 节点组件文档
  • feat:endpoint组件使用统一的创建方式文档
  • feat:增加过滤器组节点组件文档
  • feat:增加子规则链节点组件(原子规则链配置方式废弃)文档
  • feat:允许子规则链接其它节点
  • feat:functions节点组件,支持动态指定函数名
  • feat:delay节点组件,增加覆盖模式
  • feat:支持加载JavaScript脚本文件
  • feat:onEnd回调函数,支持获取ctx
  • feat:examples/server 使用独立的go.mod
  • feat:examples/server 支持是否引入扩展组件库的build tags
  • feat:mqtt client 允许重连被取消
  • fix:http endpoint 如果不是application/json无法获取body
  • fix:mqtt client 节点组件,没有重试次数限制
  • opt:Metadata修改实现方式
  • opt:rest node ReadTimeoutMs 默认值改成 0
  • opt:mqtt client config MaxReconnectInterval改成int
  • opt:Node接口OnMsg取消返回值error
  • opt:config.JsMaxExecutionTime->ScriptMaxExecutionTime
  • opt:Endpoint.AddRouterWithParams->Endpoint.AddRouter
  • opt:Endpoint.RemoveRouterWithParams->Endpoint.RemoveRouter
  • opt:RuleMetadata.RuleChainConnections标记弃用
  • opt:config.OnEnd标记弃用
  • opt:RuleEngine.OnMsgWithEndFunc标记弃用
  • opt:RuleEngine.OnMsgWithOptions标记弃用
  • opt:添加doc overview

其他信息

  • 欢迎在 Gitee 或者 Github 上提交反馈或建议
  • 文档官网:rulego.cc

相關推薦

2023-10-08

[v0.15.0] 2023/10/7 feat:增加文档官网: rulego.cc feat:增加可视化相关API。文档 feat:增加规则链全局配置Properties。文档 feat:增加规则链全局配置和自定义函数到js运行时,js脚本可以调用golang自定义函数。文档 feat:增加同步

2023-09-07

RuleGo v0.14.0 (2023/9/6) 新功能 【examples】增加大量使用示例:详情 【标准组件】增加数据库客户端节点组件(dbClient),支持mysql和postgres数据库,可以在规则链通过配置方式对数据库进行增删修改查:使用示例 【扩展组件 

2023-08-24

RuleGo v0.13.0 (2023/8/23) 新功能 新增数据集成模块(Endpoint),使用文档和介绍点击:Gitee 或者 Github 提供统一的数据处理抽象,方便异构系统数据集成,目前支持HTTP和MQTT协议 支持其他协议集成扩展,例如:kafka数据等

2022-10-11

布 NestOS 构建工具 nestos-assemble;支持 OpenStack Yoga 版本。 嵌入式场景 集成实时内核,提供 3微秒的硬实时能力。分布式软总线能力具备高安全、大带宽的数据传输和实时控制的特性,可以实现欧拉与鸿蒙的互联互通,并探索在地

2023-07-13

台模板、提升效率的主题配置系统。 新发布项目二:高性能服务网格—Kmesh 服务网格作为云原生的下一代技术,已逐步成为云上基础设施标配,但其sidecar架构存在性能问题,是当前网格技术推广的关键;Kmesh高性能服务网

2022-07-05

Vitest v0.17.0 现已发布,这是一个基于 Vite 的原生快速单元测试框架。具体更新内容如下: 新特性 添加 vite 3 支持 #1561 支持 cts 和 mts 配置  #1540 支持边缘运行时 #1574 添加缓存以运行失败和更长的测试  #1541

2023-01-19

Hugo 是一个用 Go 语言编写的静态 HTML 和 CSS 网站生成器。它针对速度、易用性和可配置性进行了优化。Hugo 将一个带有内容和模板的目录,渲染成一个完整的 HTML 网站。 错误修复 修复重复部分的 permalinks 问题 修复 resources.Ge

2023-08-17

牌的数量,从而通过减少生成响应的时间来降低成本并提高性能。  推荐系统:LLM 可以作为复杂的电子商务虚拟购物助理的支柱。Redis Enteprise 的上下文理解和语义搜索使应用程序能够理解客户查询、提供个性化产品推荐,

2022-04-11

, JavaScript/Node.js, Julia, Lisp, Lua, Perl, Python, Racket, Ruby, Rust 嵌入式、可编写脚本的终端仿真器 异步作业控制 多个编辑器实例之间的共享数据(shada)。 支持XDG基础目录 与大多数Vim插件兼容,包括Ruby和Python插件

2023-04-08

2023 年 4 月的编程语言排行榜。 受市场需求影响,高性能编程语言正蓬勃发展。鉴于此,C 和 C++ 在 top 10 中均保持着不错的表现;尤其是 C++,在摘得了 2022 年度编程语言增势不减,其增幅高达 4.68%。而 Rust

2023-03-24

保证了它的性能超越大部分解释型表达式引擎,整体非常轻量级,整个jar包大小哪怕发展到现在5.3这个版本,也才600k。 在社区中,我听到有人希望支持Aviator这个脚本语言。LiteFlow在脚本的支持度方面一直很全,既然Aviator很多

2023-12-03

钮、单选按钮、多选按钮、图片裁剪等等一系列个性化、轻量级的组件,是一款真正意义上实现组件化开发的敏捷开发框架。 软件信息 软件名称:EasyGoAdmin 敏捷开发框架 Gin+Layui 版本 官网网址:https://www.easygoadmin.vip

2023-04-12

LiteFlow介绍 LiteFlow是一个开源编排式规则引擎,能够让你的系统逻辑任意编排,可选用脚本书写逻辑,支持多达5种脚本语言,支持丰富的第三方存储的支持,所有的逻辑和规则均可热变更。设计系统和重构系统的神器。 LiteFlo

2023-07-25

LiteFlow介绍 LiteFlow是一个开源编排式规则引擎,能够让你的系统逻辑任意编排,可选用脚本书写逻辑,支持多达6种脚本语言,支持丰富的第三方存储的支持,所有的逻辑和规则均可热变更。设计系统和重构系统的神器。 LiteFlo