RuleGo v0.32.0 发布:国产轻量级、全场景、新一代组件编排规则引擎
RuleGo
是一个基于 Go
语言的轻量级、高性能、嵌入式、组件编排新一代规则引擎。它可以帮助你快速构建低耦合、灵活的系统,实现复杂的业务逻辑。RuleGo 还提供大量可复用的组件,支持对数据进行聚合、过滤、分发、转换、丰富和执行各种动作,也能和各种协议、系统进行联动和集成。让你快人一步实现自动化营销、物联网、应用集成等解决方案。
该项目在低代码、业务代码编排、数据集成、工作流、大模型智能体、边缘计算、自动化、IoT 等多种场景具有广泛的应用潜力。
典型使用场景
- 边缘计算: 可以在边缘服务器部署
RuleGo
,对数据进行预处理,筛选、聚合或者计算后再上报到云端。数据的处理规则和分发规则可以通过规则链动态配置和修改,而不需要重启系统。国产替代node-red
系统。 - 物联网: 收集设备数据上报,经过规则链的规则判断,触发一个或者多个动作,例如:发邮件、发告警、和其他设备或者系统联动。
- 数据分发: 可以根据不同的消息类型,调用 HTTP、MQTT 或者 gRPC 把数据分发到不同系统。
- 应用集成: 把
RuleGo
当做胶水连接各种系统或者协议,例如:gRPC、ssh、webhook、kafka、消息队列、数据库、chatGPT、第三方应用系统。 - 异构系统数据集中处理: 从不同的数据源(如 MQTT、HTTP、WS、MQ、gRPC、TCP/UDP 等)接收数据,然后对数据进行过滤、格式转换、然后分发到数据库、业务系统或者仪表板。
- 高度定制化业务: 把高度定制化或者经常变化的业务解耦出来,交给
RuleGo
规则链进行管理。业务需求变化而不需要重启主程序。 - 复杂业务编排: 把业务封装成自定义组件,通过
RuleGo
编排和驱动这些自定义的组件,业务逻辑并支持动态调整和替换。 - 微服务编排: 通过
RuleGo
编排和驱动微服务,或者动态调用第三方服务处理业务,并返回结果。 - 业务代码和业务逻辑解耦: 例如:用户积分计算系统、风控系统。
- 自动化: 例如:CI/CD 系统、流程自动化系统、营销自动化系统、量化系统。
- 低代码: 例如:低代码平台、iPaaS 系统、ETL、类
Langflow
、dify 系统(对接大模型
提取用户意图,然后触发规则链与其他系统进行联动或者进行业务处理)。 - MCP 服务:自动把规则链(工作流)、组件、API 自动注册成 MCP 工具,提供给 AI 智能体调用。企业应用可以很容易通过 RuleGo 的桥接,实现和 AI 智能体的联动,打通 AI 与企业应用的 “最后一公里”。
架构图
可视化
风格 1:
风格 2:
本次更新
[v0.32.0] 2025/07/11
rulego-core
- feat: endpoint/http restApiCall支持无感切换成fasthttp实现
- feat: endpoint配置支持变量替换
- feat: 规则引擎重载增加错误恢复机制
- feat: 规则引擎增加优雅关闭
- feat: 增加消息传递的写时复制(Copy-on-Write)机制
- feat: RuleMsg增加zero-copy API
- feat: RuleMsg消息负荷使用[]byte代替string
- feat: 脚本组件支持处理字节数组输入
- feat(endpoint/http): 增加读写超时配置
- feat(endpoint/ws): 改进事件注册
- feat(endpoint/net): 支持多种拆包配置
- fix: 修复多个组件OnMsg和Destroy方法之间的竞态条件
- fix: 修复表达式引擎
vm.VM
并发故障问题 - fix: 增强ReloadChild和ReloadSelf方法保护
- fix: 修复endpoint Marshal DSL循环依赖问题
- fix: 修复groupAction、groupFilter数据竞争
- fix(endpoint/mqtt): MaxReconnectInterval支持秒数配置方法
- refactor: 组件配置字段名优先从JSON tag获取
- refactor: 优化exprFilter组件初始化错误
- refactor: 改进restApiCall组件代理逻辑
- refactor: 将Config NetPool字段重命名为NodePool
- refactor: 不在支持直接访问msg.Data,使用msg.GetData()和msg.SetData('')代替
- perf: 脚本组件增加智能直通模式
- perf: 简化共享节点组件实现
- perf: 使用对象池优化DefaultRuleContext
- perf: 优化表达式获取变量性能
- perf: 所有组件和测试用例通过
-race
模式测试 - perf: 完善代码注释
- perf: 增加更多的示例和测试用例
rulego-components
- feat: 增加fasthttp组件
- feat: kafka组件增加SASL和TLS配置
- feat: Lua脚本支持处理字节流
- feat: Lua脚本支持数组转换
- feat: 增加集成测试和CI设置
- feat(ci): 增加全面的GitHub Actions CI/CD流水线和中间件测试
- feat(ci): 为所有拉取请求触发CI
- fix: 修复kafka组件重连问题
- perf: 使用零拷贝优化元数据访问
- perf: 改进生命周期管理和测试
本次重点
本次更新重点主要是优化底层架构,增强稳定性和性能,相信本次的更新将会为RuleGo作为新一代规则编排引擎底座打下坚实基础。主要以下几个方面:
- 消息传递增加写时复制(Copy-on-Write)机制,在规则链读多写少的场景,能节省80%的内存
- 消息元数据和消息负荷支持零拷贝(zero-copy) API
-
http 相关组件,支持无缝替换成fasthttp底层实现,在超过300并发情况下,能获得2-3倍的性能收益
-
部分高频对象采用对象池进行优化
-
规则引擎增加优雅关闭,强化各种资源竞争场景的保护机制,并增加了大量的测试
其他信息

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
GNOME 49 首个 Alpha 发布
GNOME 49 首个 Alpha 已发布,此版本最大的变化是默认禁用X11支持。 根据官方公告,GNOME 49计划默认禁用X11会话支持,相关代码很可能在GNOME 50中被彻底移除,从而实现仅支持Wayland的桌面环境。 新增功能 GNOME网页浏览器Epiphany:地址栏完成“重大重新设计”,并修复了大量漏洞。 GDK-Pixbuf:新增Android构建的原生加载器,现采用glycin加载SVG文件,Linux平台默认启用glycin加载器。 Glycin图像加载器:新增支持BMP、DDS、Farbfeld、GIF、ICO、JPEG、OpenEXR、PNG、PNM、QOI、TGA、TIFF和WebP格式的图像保存/编码功能。 GDM显示管理器:将X11-support默认值改为false,默认禁用X.org会话。 GNOME壁纸:新增两张骄傲月主题壁纸。 GNOME Builder集成开发环境:新增Arduino支持及其他功能增强。 GNOME计算器:新增任意根函数、排列组合、最大公约数/最小公倍数等计算功能,支持更多货币类型,增加退格键,改进无障碍访问和自适应窗口处理。...
- 下一篇
🔥 Java MCP 鉴权设计与实现指南
一、MCP 鉴权概述 MCP (Model Context Protocol) 旨在为大语言模型(LLM)与外部数据源、工具和服务提供标准化、安全的集成方式(相当于一种专用的 RPC 协议)。广泛应用于 AI 开发中的工具服务(Tool)、提示语服务(Prompt)和资源服务(Resource)。在实际应用中,确保 MCP 服务的安全性至关重要,因此需要合理的鉴权机制。 根据提供的资料,MCP 鉴权主要涉及以下几个方面: 服务端鉴权设计 客户端鉴权配置 不同通讯通道(stdio/SSE)的鉴权实现 与 Web API 互通的鉴权处理 本案基于 Solon AI MCP 进行鉴权方面的探讨: <dependency> <groupId>org.noear</groupId> <artifactId>solon-ai-mcp</artifactId> <version>最新版本</version> </dependency> 可支持 java8, java11, java17, j...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- CentOS关闭SELinux安全模块
- CentOS8安装Docker,最新的服务器搭配容器使用
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
- Hadoop3单机部署,实现最简伪集群
- SpringBoot2初体验,简单认识spring boot2并且搭建基础工程
- Linux系统CentOS6、CentOS7手动修改IP地址
- Eclipse初始化配置,告别卡顿、闪退、编译时间过长
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- Windows10,CentOS7,CentOS8安装Nodejs环境
- 设置Eclipse缩进为4个空格,增强代码规范