首页
/ RuleGo v0.29.0 版本发布:增强物联网规则引擎能力与多租户支持

RuleGo v0.29.0 版本发布:增强物联网规则引擎能力与多租户支持

2025-07-05 00:09:15作者:裘晴惠Vivianne

RuleGo 是一个基于 Go 语言开发的轻量级、高性能的物联网规则引擎框架,它允许开发者通过配置化的方式快速构建复杂的业务规则处理流程。最新发布的 v0.29.0 版本带来了多项重要功能增强和优化,进一步提升了其在物联网场景下的适用性和易用性。

核心功能增强

新增组件支持

本次更新引入了多个实用的组件,显著扩展了 RuleGo 的连接能力:

  1. 消息中间件组件:新增了 WukongIM 和 Beanstalkd 的输入与节点组件,使系统能够更方便地与这两种消息队列系统集成。WukongIM 是一个高性能的即时通讯中间件,而 Beanstalkd 是一个简单快速的工作队列服务,这些组件的加入让 RuleGo 在处理异步任务和实时消息方面有了更多选择。

  2. 工业协议支持:新增了 Modbus 读写节点组件,这是工业自动化领域广泛使用的通信协议。该组件的加入使得 RuleGo 能够直接与 PLC、传感器等工业设备进行数据交互,大大简化了工业物联网(IIoT)应用的开发。

  3. 开发工具链集成:新增了获取 Git 日志的节点组件,这一功能对于需要将代码变更与数据处理流程关联起来的场景特别有用,例如在 CI/CD 流水线中触发特定的规则处理。

大模型组件优化

对原有的大模型节点组件进行了功能完善,同时弃用了旧版实现。新版组件提供了更稳定的大模型集成能力,使开发者能够更轻松地在规则处理流程中引入 AI 能力,如自然语言处理、预测分析等。

系统架构改进

规则链验证机制

v0.29.0 引入了规则链校验拦截器,新增了两项重要的验证功能:

  1. 环路检测:系统现在能够自动检测规则链中是否存在循环引用,防止因配置错误导致的无限循环问题。

  2. 输入组件限制:明确规定子规则链不允许包含输入端组件,这一限制使得规则链的层次结构更加清晰合理,避免了潜在的逻辑混乱。

DSL 增强

在规则链的 DSL(领域特定语言)定义中,NodeConnection 增加了 Label 字段。这一看似小的改进实际上为规则链的可读性和可维护性带来了显著提升,开发者现在可以为节点间的连接关系添加描述性标签,使得复杂的规则逻辑更易于理解。

性能与稳定性优化

  1. 延迟初始化:对网络客户端组件实现了运行时的延迟初始化策略,这一改进减少了系统启动时的资源争用,提高了整体启动速度,特别是在组件数量较多的场景下效果更为明显。

  2. 错误处理改进:RestApiCall 节点组件现在会将响应错误通过 err 通道传递到下一个节点,而不是简单地丢弃或记录日志,这使得错误处理流程更加连贯和可控。

  3. 连接错误提示:优化了 MQTT 客户端连接失败时的错误提示信息,使问题诊断更加直观高效。

多租户与安全增强

RuleGo-Server 在这个版本中获得了重要的企业级功能:

  1. 多租户支持:现在可以支持多个租户在同一实例上运行,彼此隔离,这为 SaaS 化部署提供了基础。

  2. 权限控制:新增了完善的权限校验机制,确保不同角色的用户只能访问其被授权的资源。

  3. API 安全:支持通过 API Key 访问 API,为自动化集成提供了更安全的认证方式。

架构调整与未来兼容

  1. 初始化钩子增强:OnNodeBeforeInit 和 OnChainBeforeInitAspect 这两个初始化钩子现在可以获取 Config 对象,为插件和扩展提供了更大的灵活性。

  2. 组件弃用策略:明确标记了旧版大模型组件为弃用状态,引导用户迁移到新的实现,这种渐进式的演进方式既保证了兼容性,又能推动用户使用更优的解决方案。

总结

RuleGo v0.29.0 通过新增多种实用组件、增强规则链验证机制、改进系统架构以及增加多租户支持等多项改进,进一步巩固了其作为物联网规则引擎解决方案的地位。这些变化不仅提升了系统的功能和性能,也使其更加适合企业级部署和复杂场景的应用。特别是工业协议支持和多租户功能的加入,标志着 RuleGo 正在从单一的技术工具向完整的业务支撑平台演进。

登录后查看全文
热门项目推荐

项目优选

收起
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
118
174
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
158
249
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
787
483
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
149
256
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
321
1.05 K
vue3-element-adminvue3-element-admin
🔥Vue3 + Vite6+ TypeScript + Element-Plus 构建的后台管理前端模板,配套接口文档和后端源码,vue-element-admin 的 Vue3 版本。
Vue
253
43
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
382
364
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
79
2
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.04 K
0
WxJavaWxJava
微信开发 Java SDK,支持微信支付、开放平台、公众号、视频号、企业微信、小程序等的后端开发,记得关注公众号及时接受版本更新信息,以及加入微信群进行深入讨论
Java
816
22