Go語(yǔ)言輕量級(jí)高性能嵌入式規(guī)則引擎RuleGo使用詳解
背景介紹
在處理大量數(shù)據(jù)時(shí),我們經(jīng)常需要對(duì)數(shù)據(jù)進(jìn)行聚合、分發(fā)、過(guò)濾、轉(zhuǎn)換、豐富和執(zhí)行各種操作。而 RuleGo 是一個(gè)基于 Go 語(yǔ)言的輕量級(jí)、高性能、嵌入式規(guī)則引擎,可以幫助我們解決這些問(wèn)題。它可以在低成本設(shè)備上高效地處理和鏈接數(shù)據(jù),適用于物聯(lián)網(wǎng)邊緣計(jì)算。同時(shí),RuleGo 還是一個(gè)靈活、高度可定制的事件處理框架,可以滿足高度個(gè)性化或頻繁變化的業(yè)務(wù)場(chǎng)景需求。
用一句話介紹 RuleGo 項(xiàng)目就是:“RuleGo is a lightweight, high-performance, embedded rule engine based on Go language. It can aggregate, distribute, filter, transform, enrich and execute various actions on input messages.”。
項(xiàng)目介紹
RuleGo 是一個(gè)基于編排的規(guī)則引擎,最擅長(zhǎng)解耦系統(tǒng)。它采用協(xié)程池和對(duì)象池等技術(shù),結(jié)合 Go 語(yǔ)言的高性能特性,可以在10W 數(shù)據(jù)處理 JS 腳本過(guò)濾-> JS 腳本數(shù)據(jù)處理-> HTTP 推送的情況下,平均處理時(shí)間為 9 秒。同時(shí),RuleGo 支持將自己嵌入到現(xiàn)有項(xiàng)目中,非侵入式地利用其特性。所有業(yè)務(wù)邏輯都是組件化的,可以靈活配置和重用。你可以靈活地組合和重用不同的組件,以實(shí)現(xiàn)高度可定制和可擴(kuò)展的業(yè)務(wù)流程。支持規(guī)則鏈的動(dòng)態(tài)編排,你可以將你的業(yè)務(wù)封裝成 RuleGo 組件,通過(guò)構(gòu)建塊實(shí)現(xiàn)高度變化的業(yè)務(wù)需求。
同時(shí),RuleGo 提供了豐富靈活的擴(kuò)展接口和鉤子,如:自定義組件、組件注冊(cè)管理、規(guī)則鏈 DSL 解析器、協(xié)程池、規(guī)則節(jié)點(diǎn)消息流入/流出回調(diào)、規(guī)則鏈處理結(jié)束回調(diào)等。支持通過(guò) Go 插件動(dòng)態(tài)加載組件和擴(kuò)展組件。內(nèi)置常用組件包括:消息類型切換、JavaScript 切換、JavaScript 過(guò)濾器、JavaScript 轉(zhuǎn)換器、HTTP 推送、MQTT 推送、發(fā)送電子郵件、日志記錄等組件。你也可以自己擴(kuò)展其他組件。同時(shí),RuleGo 還具有可靠的上下文隔離機(jī)制,無(wú)需擔(dān)心高并發(fā)情況下的數(shù)據(jù)流問(wèn)題。
如何使用
你可以通過(guò)以下步驟安裝和使用 RuleGo:
1、安裝 Go 語(yǔ)言環(huán)境
2、執(zhí)行命令:go get github.com/rulego/rulego
3、在你的代碼中引入 RuleGo 包
4、編寫規(guī)則鏈,進(jìn)行業(yè)務(wù)處理
對(duì)于以上鏈?zhǔn)秸{(diào)用關(guān)系,可以用如下 JSON DSL 進(jìn)行描述。
{ "ruleChain": { "name": "Test rule chain", "root": true, "debugMode": false }, "metadata": { "nodes": [ { "id": "s1", "type": "jsFilter", "name": "Filtering Data", "debugMode": true, "configuration": { "jsScript": "return msg!='bb';" } }, { "id": "s2", "type": "jsTransform", "name": "Transform Data", "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": "Call Rest Api Push Data", "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 } }
如果你想了解更多使用方法,可以參考項(xiàng)目文檔中的示例代碼。
項(xiàng)目推介
RuleGo是一個(gè)非常優(yōu)秀的開源項(xiàng)目,它的開發(fā)活躍度很高,已經(jīng)獲得了很多開發(fā)者的認(rèn)可和使用。它還被一些知名公司和業(yè)內(nèi)知名人士推薦使用。如果你需要一個(gè)高性能、靈活、可定制的規(guī)則引擎,RuleGo 將是一個(gè)非常好的選擇。
以下是該項(xiàng)目 Star 趨勢(shì)圖(代表項(xiàng)目的活躍程度):
開源項(xiàng)目地址:https://github.com/rulego/rulego
以上就是Go語(yǔ)言輕量級(jí)高性能嵌入式規(guī)則引擎RuleGo使用詳解的詳細(xì)內(nèi)容,更多關(guān)于Go RuleGo規(guī)則引擎的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
深入剖析Go語(yǔ)言中數(shù)組和切片的區(qū)別
本文將深入探討 Go 語(yǔ)言數(shù)組和切片的區(qū)別,包括它們的定義、內(nèi)存布局、長(zhǎng)度和容量、初始化和操作等方面。從而更好地在實(shí)際開發(fā)中選擇和使用合適的數(shù)據(jù)結(jié)構(gòu),提高代碼的效率和可維護(hù)性,需要的可以參考一下2023-05-05Golang中 import cycle not allowed 問(wèn)題
這篇文章主要介紹了Golang中 import cycle not allowed 問(wèn)題的解決方法,問(wèn)題從描述到解決都非常詳細(xì),需要的小伙伴可以參考一下2022-03-03詳解Go語(yǔ)言中關(guān)于包導(dǎo)入必學(xué)的 8 個(gè)知識(shí)點(diǎn)
這篇文章主要介紹了詳解Go語(yǔ)言中關(guān)于包導(dǎo)入必學(xué)的 8 個(gè)知識(shí)點(diǎn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08Go語(yǔ)言實(shí)現(xiàn)定時(shí)器的方法
這篇文章主要介紹了Go語(yǔ)言實(shí)現(xiàn)定時(shí)器的方法,涉及Go語(yǔ)言時(shí)間操作技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-02-02Go函數(shù)使用(函數(shù)定義、函數(shù)聲明、函數(shù)調(diào)用等)
本文主要介紹了Go函數(shù)使用,包括函數(shù)定義、函數(shù)聲明、函數(shù)調(diào)用、可變參數(shù)函數(shù)、匿名函數(shù)、遞歸函數(shù)、高階函數(shù)等,感興趣的可以了解一下2023-11-11GO中使用谷歌GEMINI模型任務(wù)代碼實(shí)例
這篇文章主要為大家介紹了GO中使用谷歌GEMINI模型任務(wù)代碼實(shí)例探究,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2024-01-01