首页
/ RuleGo v0.31.0 版本发布:增强缓存与脚本能力,优化节点功能

RuleGo v0.31.0 版本发布:增强缓存与脚本能力,优化节点功能

2025-07-05 18:07:35作者:丁柯新Fawn

RuleGo 是一个基于 Go 语言开发的轻量级、高性能、可嵌入的规则引擎框架,它允许开发者通过配置化的方式定义复杂的事件处理流程。RuleGo 采用组件化设计,支持动态加载和热更新规则链,非常适合物联网、消息处理、自动化运维等场景。

核心功能增强

新增缓存组件与操作能力

本次版本最显著的改进之一是引入了缓存功能。RuleGo 现在提供了三个新的组件节点:cacheSet、cacheGet 和 cacheDelete,使得规则链可以直接操作缓存数据。这一功能扩展了 RuleGo 的状态管理能力,使得规则可以:

  1. 临时存储中间计算结果
  2. 实现简单的状态跟踪
  3. 缓存外部API调用结果以提高性能

值得注意的是,缓存功能不仅可以通过节点操作,还直接暴露给了脚本引擎。无论是 JavaScript 还是 Lua 脚本,现在都可以直接调用缓存相关方法,这大大增强了脚本处理复杂逻辑的能力。

脚本引擎功能统一与增强

RuleGo 一直支持通过脚本扩展处理逻辑,v0.31.0 版本对脚本功能做了重要改进:

  1. 统一了 JavaScript 和 Lua 的自定义函数注册方法,降低了学习成本
  2. 支持将所有结构体导出函数绑定到脚本环境中,极大扩展了脚本可调用功能
  3. Lua 脚本现在可以调用与 JavaScript 相同的用户自定义函数(UDF)

这些改进使得脚本开发更加统一和强大,开发者可以根据项目需求或个人偏好选择 JavaScript 或 Lua,而不用担心功能差异。

节点功能优化

REST API 调用增强

restApiCall 节点是 RuleGo 中用于调用外部 HTTP 接口的重要组件,新版本对其做了多项改进:

  1. 允许完全自定义请求体(body)内容
  2. 优化了变量取值逻辑,使得参数配置更加灵活
  3. 修复了请求失败时错误信息无法传递到元数据的问题

现在开发者可以更灵活地构建复杂的 HTTP 请求,特别是在需要动态构造请求体或处理错误场景时更加方便。

其他节点改进

  1. Switch 节点修复了配置不能完全覆盖默认 cases 参数的问题
  2. Join 节点现在能够正确收集错误节点信息
  3. 节点配置现在支持混合字符串和变量取值,提高了配置灵活性

端点(Endpoint)功能增强

RuleGo 的端点系统也获得了多项改进:

  1. 添加了 HasRouter API,方便检查路由是否存在
  2. 端点现在可以获取规则链的 DSL 定义
  3. REST 端点重启时增加了关闭超时机制,提高稳定性
  4. 修复了共享节点热更新时路由恢复的问题

特别值得一提的是新增的 MCP Server Endpoint,这为 RuleGo 提供了新的通信协议支持,扩展了其应用场景。

编辑器与服务器改进

RuleGo Editor 作为可视化规则链设计工具,也同步更新:

  1. 新增了缓存组件节点,方便可视化配置
  2. 增强了 REST 节点的 body 参数配置界面
  3. 添加了 MCP Server Endpoint 节点支持
  4. 修复了快捷键操作问题,优化了集成显示

RuleGo Server 作为独立服务版本,修复了 HTTP 服务器重启后编辑器路由丢失的问题,并集成了系统默认的 HTTP 服务器。

总结

RuleGo v0.31.0 版本通过引入缓存功能、统一脚本引擎、增强节点能力等一系列改进,进一步提升了框架的实用性和灵活性。这些改进使得 RuleGo 在处理复杂业务逻辑、集成外部系统、管理应用状态等方面更加强大。特别是缓存功能的加入,为需要状态管理的场景提供了原生支持,而脚本引擎的增强则让自定义逻辑开发更加便捷。

对于现有用户,建议关注节点配置语法和脚本API的变化,特别是REST API调用和脚本函数注册方式的改进。新用户可以借助这些增强功能更快地构建复杂的规则处理系统。

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

热门内容推荐

项目优选

收起
openHiTLS-examplesopenHiTLS-examples
本仓将为广大高校开发者提供开源实践和创新开发平台,收集和展示openHiTLS示例代码及创新应用,欢迎大家投稿,让全世界看到您的精巧密码实现设计,也让更多人通过您的优秀成果,理解、喜爱上密码技术。
C
54
469
kernelkernel
deepin linux kernel
C
22
5
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
7
0
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
880
519
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
336
1.1 K
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
181
264
cjoycjoy
一个高性能、可扩展、轻量、省心的仓颉Web框架。Rest, 宏路由,Json, 中间件,参数绑定与校验,文件上传下载,MCP......
Cangjie
87
14
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.09 K
0
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
361
381
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
612
60