RuleGo v0.24.0 发布:国产轻量级、全场景、新一代组件编排规则引擎
RuleGo
是一个基于 Go
语言的轻量级、高性能、嵌入式、组件编排新一代规则引擎。它可以帮助你快速构建低耦合、灵活的系统,实现复杂的业务逻辑。RuleGo 还提供大量可复用的组件,支持对数据进行聚合、过滤、分发、转换、丰富和执行各种动作,也能和各种协议、系统进行联动和集成。让你快人一步实现自动化营销、物联网、应用集成等解决方案。
该项目在低代码、业务代码编排、数据集成、工作流、大模型智能体、边缘计算、自动化、IoT 等多种场景具有广泛的应用潜力。
典型使用场景
- 边缘计算: 可以在边缘服务器部署
RuleGo
,对数据进行预处理,筛选、聚合或者计算后再上报到云端。数据的处理规则和分发规则可以通过规则链动态配置和修改,而不需要重启系统。国产替代node-red
系统。 - 物联网: 收集设备数据上报,经过规则链的规则判断,触发一个或者多个动作,例如:发邮件、发告警、和其他设备或者系统联动。
- 数据分发: 可以根据不同的消息类型,调用 HTTP、MQTT 或者 gRPC 把数据分发到不同系统。
- 应用集成: 把
RuleGo
当做胶水连接各种系统或者协议,例如:ssh、webhook、kafka、消息队列、数据库、chatGPT、第三方应用系统。 - 异构系统数据集中处理: 从不同的数据源(如 MQTT、HTTP、WS、TCP/UDP 等)接收数据,然后对数据进行过滤、格式转换、然后分发到数据库、业务系统或者仪表板。
- 高度定制化业务: 把高度定制化或者经常变化的业务解耦出来,交给
RuleGo
规则链进行管理。业务需求变化而不需要重启主程序。 - 复杂业务编排: 把业务封装成自定义组件,通过
RuleGo
编排和驱动这些自定义的组件,业务逻辑并支持动态调整和替换。 - 微服务编排: 通过
RuleGo
编排和驱动微服务,或者动态调用第三方服务处理业务,并返回结果。 - 业务代码和业务逻辑解耦: 例如:用户积分计算系统、风控系统。
- 自动化: 例如:CI/CD 系统、流程自动化系统、营销自动化系统。
- 低代码: 例如:低代码平台、iPaaS 系统、ETL、类
Langflow
系统(对接大模型
提取用户意图,然后触发规则链与其他系统进行联动或者进行业务处理)。
架构图
可视化
本次更新
[v0.24.0] 2024/09/09
- feat:增加节点连接资源复用机制
- feat:网络连接类组件支持共享连接池
- feat:增加引用节点的节点
- feat:exec node允许通过stderr获取数据
- feat:http endpoint允许响应html页面
- fix(server):post msg api没有workDir
- feat(server):增加节点复用相关api
- feat(server):加载全局共享组件
- feat(rulego-components):增加rabbitmq endpoint和节点组件
- feat(rulego-components):增加opengemini读和opengemini写组件
- feat(rulego-components):组件支持连接池
- refactor(rulego-components):kafka组件brokers字段改成server
- feat(rulego-editor):规则链ID默认使用nanoid
- feat(rulego-editor):endpoint支持多路由
- feat(rulego-editor):增加连接类型国际化
- feat(rulego-editor):增加连接池下拉选项
- feat(rulego-editor):增加最新版本节点配置
本次重点
- 本次更新实现了两种复用组件机制:
- 网络类组件客户端共享机制,允许多个组件共用同一个客户端连接资源,达到连接复用的目的。
- 引用组件的组件,允许引用当前规则链或者别的规则链某一个节点,达到节点复用目的。
另外框架提供了更加灵活的规则引擎逻辑控制方法,你可以实现更高级的自定义组件功能。
- 内置组件方面
本次新增5个内置组件,分别是:rabbitmq endpoint 组件、rabbitmq 节点组件、opengemini读和写组件、节点引用组件。
RuleGo除了提供规则解析和组件编排外,还内置了大量的开箱即用的公共组件。你可以很方便通过统一的配置方式动态调用以下组件:
- 数据库:支持sqlite3、mysql、postgres、Microsoft SQL Server、Oracle、TDengine、Snowflake、ClickHouse、Vertica、opengemini、influxdb
- 消息队列:mqtt、redis sub、redis stream、rabbitmq、nats
- 脚本语言:Lua、JavaScript、Expr表达式
- 协议类:tcp/udp、http、websocket、ssh、命令行
- 控制类:for、if、节点引用、子规则链、节点组、消息路由、延迟、定时调度
- 通知类:webhook(钉钉、企业微信、飞书等)、邮件、消息模板
其他信息
- 欢迎在 Gitee 或者 Github 上提交反馈或建议
- 如果喜欢这个项目,请给我们点个 Star
- 文档官网:rulego.cc
- rulego-editor:editor.rulego.cc
- 体验地址

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
解读 GaussDB (for MySQL) 冷热存储分离实现原理
摘要:GaussDB (for MySQL) 冷热存储分离特性,支持用户直接针对 Innodb 的 page 进行归档和回迁操作,且无需调整上层业务即可访问冷数据。 本文分享自华为云社区《GaussDB (for MySQL) 新特性解读:冷热存储分离》,作者:GaussDB 数据库。 技术背景 业务长期运行,但随着时间推移,越来越多的数据被访问频率降低,从而变成为所谓的"冷数据"。若直接将这些冷数据删除,会面临数据丢失的风险以及高昂的恢复成本;若保持冷数据现有的存储方式不变,存储空间占用越来越多,存储成本将持续增加。 同时,在无法有效利用查询索引加速的情况下,数据表的记录膨胀会进一步降低查询效率。如若用户自己识别、分离并转存冷数据至低成本存储中,需要考虑诸多因素: a. 如何构建脚本。从表中 dump 一行行冷数据到 OBS 等超低成本存储中,这需要借助其它计算资源完成; b. 如何提升在线迁移效率,同时降低对现有业务性能的影响; c. 如何保障数据一致性和可靠性,并在出现问题时快速处理; d. 当导出的数据无法直接访问时,如何倒回到实例的表中; … 这一系列问题,不仅涉及的改造工程...
- 下一篇
🎉 降低 DDD 实践成本 | Wow 3.12.6 发布
领域驱动|事件驱动|测试驱动|声明式设计|响应式编程|命令查询职责分离|事件溯源 官方文档:https://wow.ahoo.me/ 更新内容 特性(query): 支持或非(NOR)逻辑运算符。 依赖(dashboard): 更新typescript到~5.5.0。 依赖(opentelemetry): 更新io.opentelemetry:opentelemetry-bom到1.42.0。 依赖(build): 更新detekt到1.23.7。 依赖(dashboard): 更新jasmine-core到~5.3.0。 QueryDsl condition { deleted(false) and { tenantId("tenantId") all() } nor { all() } id("id") ids("id", "id2") "field1" eq "value1" "field2" ne "value2" "filed3" gt 1 "field4" lt 1 "field5" gte 1 "field6" lte 1 "fiel...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- CentOS7设置SWAP分区,小内存服务器的救世主
- Mario游戏-低调大师作品
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- 2048小游戏-低调大师作品
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- MySQL8.0.19开启GTID主从同步CentOS8
- CentOS8安装Docker,最新的服务器搭配容器使用
- CentOS8安装MyCat,轻松搞定数据库的读写分离、垂直分库、水平分库
- CentOS7编译安装Cmake3.16.3,解决mysql等软件编译问题
- CentOS7,CentOS8安装Elasticsearch6.8.6