RuleGo 正在参加 2021 年度 OSC 中国开源项目评选,请投票支持!
RuleGo 在 2021 年度 OSC 中国开源项目评选 中已获得 {{ projectVoteCount }} 票,请投票支持!
2021 年度 OSC 中国开源项目评选 正在火热进行中,快来投票支持你喜欢的开源项目!
2021 年度 OSC 中国开源项目评选 >>> 中场回顾
RuleGo 获得 2021 年度 OSC 中国开源项目评选「最佳人气项目」 !
授权协议 Apache
开发语言 Google Go
操作系统 跨平台
软件类型 开源软件
开源组织
地区 国产
投 递 者 rulego_team
适用人群 未知
收录时间 2023-07-28

软件简介

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

特性


  • 轻量级:无外部中间件依赖,既可以下沉到边缘服务器,实现物联网边缘计算解决方案,也可以部署在云端,作为规则引擎服务。
  • 高性能:得益于Go的高性能特性,另外RuleGo采用协程池和对象池等技术。对10W条数据进行JS脚本过滤->JS脚本数据处理->HTTP推送 处理,平均用时9秒。
  • 嵌入式:支持把RuleGo嵌入到现有项目,非入侵式利用其特性。
  • 组件化:所有业务逻辑都是组件,并能灵活配置和重用它们。
  • 规则链:可以灵活地组合和重用不同的组件,实现高度定制化和可扩展性的业务流程。
  • 流程编排:支持对规则链进行动态编排,你可以把业务地封装成RuleGo组件,然后通过搭积木方式实现你高度变化的业务需求。
  • 扩展简单:提供丰富灵活的扩展接口和钩子,如:自定义组件、组件注册管理、规则链DSL解析器、协程池、规则节点消息流入/流出回调、规则链处理结束回调。
  • 动态加载:支持通过Go plugin 动态加载组件和扩展组件。
  • 内置常用组件:消息类型Switch,JavaScript Switch,JavaScript过滤器,JavaScript转换器,HTTP推送MQTT推送发送邮件日志记录 等组件。可以自行扩展其他组件。
  • 上下文隔离机制:可靠的上下文隔离机制,无需担心高并发情况下的数据串流。

使用场景

RuleGo是一款编排式的规则引擎,最擅长去解耦你的系统。

  • 如果你的系统业务复杂,并且代码臃肿不堪
  • 如果你的业务场景高度定制化或者经常变动
  • 或者需要端对端的物联网解决方案
  • 或者需要对异构系统数据集中处理
  • 或者你想尝试在Go语言实现热部署......
    RuleGo框架会是一个非常好的解决方案。

典型使用场景

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

安装


使用go get命令安装RuleGo

go get github.com/rulego/rulego

使用


使用Json格式定义规则链DSL:

{
  "ruleChain": {
    "name": "测试规则链",
    "root": true
  },
  "metadata": {
    "nodes": [
      {
        "id": "s1",
        "type": "jsFilter",
        "name": "过滤",
        "debugMode": true,
        "configuration": {
          "jsScript": "return msg!='bb';"
        }
      },
      {
        "id": "s2",
        "type": "jsTransform",
        "name": "转换",
        "debugMode": true,
        "configuration": {
          "jsScript": "metadata['test']='test02';\\\\n metadata['index']=50;\\\\n msgType='TEST_MSG_TYPE2';\\\\n var msg2=JSON.parse(msg);\\\\n msg2['aa']=66;\\\\n return {'msg':msg2,'metadata':metadata,'msgType':msgType};"
        }
      },
      {
        "id": "s3",
        "type": "restApiCall",
        "name": "推送数据",
        "debugMode": true,
        "configuration": {
          "restEndpointUrlPattern": "http://192.168.216.21:9099/api/socket/msg",
          "requestMethod": "POST",
          "maxParallelRequestsCount": 200
        }
      }
    ],
    "connections": [
      {
        "fromId": "s1",
        "toId": "s2",
        "type": "True"
      },
      {
        "fromId": "s2",
        "toId": "s3",
        "type": "Success"
      }
    ],
    "ruleChainConnections": null
  }
}

导入RuleGo包并创建一个规则引擎实例:

import "github.com/rulego/rulego"

//创建一个规则引擎实例,每个规则引擎实例有且只有一个根规则链
ruleEngine, err := rulego.New("rule01", []byte(ruleFile))

把消息、消息类型、消息元数据交给规则引擎实例处理:

//定义消息元数据
metaData := types.NewMetadata()
metaData.PutValue("productType", "test01")
//定义消息和消息类型
msg := types.NewMsg(0, "TELEMETRY_MSG", types.JSON, metaData, "{\\"temperature\\":35}")

//把消息交给规则引擎处理
ruleEngine.OnMsg(msg)

//需要得到结束回调的调用方式
ruleEngine.OnMsgWithOptions(msg,types.WithEndFunc(func(msg types.RuleMsg, err error) {
//规则链异步回调结果 
//注意:规则链如果有多个分支结束点,会调用多次
}))

//带context.Context的调用方式,用于不同组件实例共享数据
ruleEngine.OnMsgWithOptions(msg,types.WithContext(context.WithValue(context.Background(), "shareKey", "shareValue")))

支持规则链类型:

顺序执行:


异步+顺序执行:


使用子规则链方式:


一些复杂例子:

源代码/文档:

Gitee

Github

展开阅读全文

代码

的 Gitee 指数为
超过 的项目

评论

点击引领话题📣 发布并加入讨论🔥
发表了资讯
昨天 21:57

RuleGo v0.27.0 发布,重大更新:开箱即用的规则引擎中间件-RuleGo-Server

RuleGo 是一个基于 Go 语言的轻量级、高性能、嵌入式、组件编排新一代规则引擎。它可以帮助你快速构建低耦合、灵活的系统,实现复杂的业务逻辑。RuleGo 还提供大量可复用的组件,支持对数据进行聚合、过滤、分发、转换、丰富和执行各种动作,也能和各种协议、系统进行联动和集成。让你快人一步实现自动化营销、物联网、应用集成等解决方案。 该项目在低代码、业务代码编排、数据集成、工作流、大模型智能体、边缘计算、自动化、...

0
1
发表了资讯
前天 19:47

RuleGo v0.27.0 发布,高性能规则引擎

RuleGo v0.27.0 已经发布,高性能规则引擎 此版本更新内容包括: [v0.27.0] 2024/12/08 feat:允许获得endpoint router错误 feat:规则链DSL增加Disabled字段 feat(endpoint/rest):允许设置跨域 feat(restApiCallNode):允许配置不校验证书 feat(flow):子规则链允许设置成继承模式 feat:如果规则链Disabled,则初始化引擎错误 feat(groupActionNode):节点ID列表允许string和数组格式 feat(builtin):增加toHex和setJsonDataType内置...

0
0
发表了资讯
11/07 09:39

RuleGo v0.26.0 发布:国产轻量级、全场景、新一代组件编排规则引擎

RuleGo 是一个基于 Go 语言的轻量级、高性能、嵌入式、组件编排新一代规则引擎。它可以帮助你快速构建低耦合、灵活的系统,实现复杂的业务逻辑。RuleGo 还提供大量可复用的组件,支持对数据进行聚合、过滤、分发、转换、丰富和执行各种动作,也能和各种协议、系统进行联动和集成。让你快人一步实现自动化营销、物联网、应用集成等解决方案。 该项目在低代码、业务代码编排、数据集成、工作流、大模型智能体、边缘计算、自动化、...

0
5
发表了资讯
10/07 09:01

RuleGo v0.25.0 发布:国产轻量级、全场景、新一代组件编排规则引擎

RuleGo 是一个基于 Go 语言的轻量级、高性能、嵌入式、组件编排新一代规则引擎。它可以帮助你快速构建低耦合、灵活的系统,实现复杂的业务逻辑。RuleGo 还提供大量可复用的组件,支持对数据进行聚合、过滤、分发、转换、丰富和执行各种动作,也能和各种协议、系统进行联动和集成。让你快人一步实现自动化营销、物联网、应用集成等解决方案。 该项目在低代码、业务代码编排、数据集成、工作流、大模型智能体、边缘计算、自动化、...

4
2
发表了资讯
09/09 09:40

RuleGo v0.24.0 发布:国产轻量级、全场景、新一代组件编排规则引擎

RuleGo 是一个基于 Go 语言的轻量级、高性能、嵌入式、组件编排新一代规则引擎。它可以帮助你快速构建低耦合、灵活的系统,实现复杂的业务逻辑。RuleGo 还提供大量可复用的组件,支持对数据进行聚合、过滤、分发、转换、丰富和执行各种动作,也能和各种协议、系统进行联动和集成。让你快人一步实现自动化营销、物联网、应用集成等解决方案。 该项目在低代码、业务代码编排、数据集成、工作流、大模型智能体、边缘计算、自动化、...

1
2
发表了资讯
08/12 09:22

RuleGo v0.23.0 发布:国产轻量级、全场景、新一代组件编排规则引擎

RuleGo 是一个基于 Go 语言的轻量级、高性能、嵌入式、组件编排新一代规则引擎。它可以帮助你快速构建低耦合、灵活的系统,实现复杂的业务逻辑。RuleGo 还提供大量可复用的组件,支持对数据进行聚合、过滤、分发、转换、丰富和执行各种动作,也能和各种协议、系统进行联动和集成。让你快人一步实现自动化营销、物联网、应用集成等解决方案。 该项目在低代码、业务代码编排、数据集成、工作流、大模型智能体、边缘计算、自动化、...

1
1
发表了资讯
07/07 23:53

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

首先祝贺RuleGo获得“Gitee 2024最有价值开源项目“奖项(GVP),感谢Gitee评审团队的认可。 RuleGo 是一个基于 Go 语言的轻量级、高性能、嵌入式、组件编排新一代规则引擎。支持异构系统数据集成、系统联动、业务逻辑动态编排,可以对输入消息进行聚合、分发、过滤、转换、丰富和执行各种动作。 典型使用场景 边缘计算: 可以在边缘服务器部署 RuleGo,对数据进行预处理,筛选、聚合或者计算后再上报到云端。数据的处理规则和分...

0
7
发表了资讯
06/19 13:04

寻找共同开发者参与 RuleGo 项目的多元化发展

我正在寻找对 RuleGo 项目感兴趣的开发者,共同推进这个项目的发展。RuleGo 是基于 Go 语言的轻量级、高性能、嵌入式、可扩展的组件编排规则引擎框架。 它在低代码、数据集成、异构系统集成、工作流、大模型智能体、边缘计算、自动化、IoT 等多种场景具有广泛的应用潜力。 目前,我们正在寻找有兴趣参与以下领域的开发者: RuleGO Core 版本迭代以及优化。 开发 规则链 Loader,以提高规则加载的效率和灵活性。 优化 RuleGo 引擎...

0
0
发表了资讯
06/07 11:27

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

RuleGo 是一个基于 Go 语言的轻量级、高性能、嵌入式、组件编排规则引擎。也一个灵活配置和高度定制化的事件处理框架。支持异构系统数据集成,可以对输入消息进行聚合、分发、过滤、转换、丰富和执行各种动作。 典型使用场景 边缘计算: 可以在边缘服务器部署 RuleGo,对数据进行预处理,筛选、聚合或者计算后再上报到云端。数据的处理规则和分发规则可以通过规则链动态配置和修改,而不需要重启系统。 物联网: 收集设备数据上...

0
2
发表了资讯
04/24 00:03

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

RuleGo 是一个基于 Go 语言的轻量级、高性能、嵌入式、组件编排规则引擎。也一个灵活配置和高度定制化的事件处理框架。支持异构系统数据集成,可以对输入消息进行聚合、分发、过滤、转换、丰富和执行各种动作。 典型使用场景 边缘计算: 可以在边缘服务器部署 RuleGo,对数据进行预处理,筛选、聚合或者计算后再上报到云端。数据的处理规则和分发规则可以通过规则链动态配置和修改,而不需要重启系统。 物联网: 收集设备数据上...

0
4
发表了资讯
02/18 16:08

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

RuleGo 是一个基于 Go 语言的轻量级、高性能、嵌入式、组件编排规则引擎。也一个灵活配置和高度定制化的事件处理框架。支持异构系统数据集成,可以对输入消息进行聚合、分发、过滤、转换、丰富和执行各种动作。 典型使用场景 边缘计算: 可以在边缘服务器部署 RuleGo,对数据进行预处理,筛选、聚合或者计算后再上报到云端。数据的处理规则和分发规则可以通过规则链动态配置和修改,而不需要重启系统。 物联网: 收集设备数据上...

0
10
发表了资讯
2023/12/25 13:33

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

RuleGo 是一个基于 Go 语言的轻量级、高性能、嵌入式、可编排组件式的规则引擎。也一个灵活配置和高度定制化的事件处理框架。支持异构系统数据集成,可以对输入消息进行聚合、分发、过滤、转换、丰富和执行各种动作。 典型使用场景 边缘计算: 可以在边缘服务器部署 RuleGo,对数据进行预处理,筛选、聚合或者计算后再上报到云端。数据的处理规则和分发规则可以通过规则链动态配置和修改,而不需要重启系统。 物联网: 收集设备...

2
6
发表了资讯
2023/11/26 17:52

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

RuleGo是一个基于Go语言的轻量级、高性能、嵌入式、可编排组件式的规则引擎。也一个灵活配置和高度定制化的事件处理框架。支持异构系统数据集成,可以对输入消息进行聚合、分发、过滤、转换、丰富和执行各种动作。 典型使用场景 边缘计算: 可以在边缘服务器部署RuleGo,对数据进行预处理,筛选、聚合或者计算后再上报到云端。数据的处理规则和分发规则可以通过规则链动态配置和修改,而不需要重启系统。 物联网: 收集设备数据...

5
5
发表了资讯
2023/10/30 11:23

🎉RuleGo v0.16.0 发布:Go轻量级、高性能、嵌入式、可编排组件式规则引擎-可视化来了

[v0.16.0] 2023/11/1 feat:提供规则链可视化编辑器RuleGo-Editor 在线使用 feat:增加ssh节点组件 文档 feat:增加延迟节点组件 文档 feat:增加functions节点组件 文档 feat:dbClient节点组件支持手动导入数据库驱动,例如:TDengine feat:增加schedule endpoint组件 文档 feat:http endpoint增加global options handler feat:增加作为中间件独立运行的规则引擎示例工程,并提供二进制文件 examples/server feat:endpoint.AddRou...

0
3
发表了资讯
2023/10/07 15:22

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

[v0.15.0] 2023/10/7 feat:增加文档官网: rulego.cc feat:增加可视化相关API。文档 feat:增加规则链全局配置Properties。文档 feat:增加规则链全局配置和自定义函数到js运行时,js脚本可以调用golang自定义函数。文档 feat:增加同步调用规则链方式:OnMsgAndWait。 feat:http Endpoint支持把规则链处理结果响应给前端。 feat:Endpoint模块,路由增加Wait()语义,表示同步等待规则链执行结果。 feat:增加批量触发规则引擎实例池所有...

1
3
发表了资讯
2023/09/06 15:43

RuleGo v0.14.0 发布:Go 轻量级、高性能、嵌入式、编排式的规则引擎

RuleGo v0.14.0 (2023/9/6) 新功能 【examples】增加大量使用示例:详情 【标准组件】增加数据库客户端节点组件(dbClient),支持mysql和postgres数据库,可以在规则链通过配置方式对数据库进行增删修改查:使用示例 【扩展组件 】增加redis客户端节点组件(x/redisClient):使用示例 【规则链引擎】增加加载指定路径文件夹所有规则链功能 【HTTP Endpoint组件】URL Query参数自动存放到msg.Metadata 【msg】 msg.Metadata value允...

2
5
发表了资讯
2023/08/23 18:46

RuleGo v0.13.0 正式发布:Go 轻量级、高性能、嵌入式、编排式的规则引擎

RuleGo v0.13.0 (2023/8/23) 新功能 新增数据集成模块(Endpoint),使用文档和介绍点击:Gitee 或者 Github 提供统一的数据处理抽象,方便异构系统数据集成,目前支持HTTP和MQTT协议 支持其他协议集成扩展,例如:kafka数据等 支持统一的数据路由和数据响应 新增字段过滤器组件(fieldFilter) 新增RuleEngine.OnMsgWithOptions方法,支持传递context和共享数据 组件支持ctx.GetContext().Value(shareKey)获取共享数据 修复 修复R...

1
3
发表了资讯
2023/07/28 14:18

RuleGo v0.12.0 正式发布:Go 语言的轻量级、高性能、嵌入式业务规则引擎

软件简介 RuleGo 是一个基于 Go 语言的轻量级、高性能、嵌入式的规则引擎。也一个灵活配置和高度定制化的事件处理框架。可以对输入消息进行过滤、转换、丰富和执行各种动作。 本项目很大程度受 thingsboard 启发。参考其规则链思想,但在架构上做了重大调整,来满足以下场景: 在资源占用和性能上做了很大程度优化,使其更适用边缘计算场景。 不停机、不需要重新编译,动态编排业务,满足高度定制化和高度变化的业务需求。 非侵入...

3
13
没有更多内容
加载失败,请刷新页面
点击加载更多
加载中
下一页
发表了博客
{{o.pubDate | formatDate}}

{{formatAllHtml(o.title)}}

{{parseInt(o.replyCount) | bigNumberTransform}}
{{parseInt(o.viewCount) | bigNumberTransform}}
没有更多内容
暂无内容
发表了问答
{{o.pubDate | formatDate}}

{{formatAllHtml(o.title)}}

{{parseInt(o.replyCount) | bigNumberTransform}}
{{parseInt(o.viewCount) | bigNumberTransform}}
没有更多内容
暂无内容
暂无内容
0 评论
23 收藏
分享
OSCHINA
登录后可查看更多优质内容
返回顶部
顶部