色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

不同規則引擎在核心編排上的優缺點

電子工程師 ? 來源:OSC開源社區 ? 作者:OSC開源社區 ? 2022-08-08 15:23 ? 次閱讀

本文主要介紹 ice 的核心編排思想,并與常見編排思想 (如 Drools/Activity 等) 做了比較。

背景介紹

業務中是否寫了大量的 if-else?是否受夠了這些 if-else 還要經常變動?業務中是否做了大量抽象,發現新的業務場景還是用不上?是否各種調研規則引擎,發現不是太重就是接入或維護太麻煩,最后發現還是不如硬編碼?接下來給大家介紹一款全新的開源規則引擎 ——ice,以一個簡單的例子,從最底層的編排思想,闡述 ice 與其他規則引擎的不同;講述 ice 是如何使用全新的設計思想,契合解耦和復用的屬性,還你最大的編排自由度。規則引擎的應用場景規則引擎在很多業務場景中都有應用,例如:會員營銷:由多種條件、流程、獎勵組合而成,時間線復雜,代碼復用率不高,調整頻繁風控規則:由多種條件組合并返回決策,條件量大且復雜,變動頻繁數據分析:將數據通過分析師自己編排的規則產出想要的數據,千人千面以上場景往往都存在一些共同痛點:靈活業務(變動頻繁,時效性明顯,測試邏輯復雜)追求靈活花里胡哨:產品和運營一直在探索新鮮玩法,導致很多抽象出來的模塊往往扛不過兩個迭代。今天上線又要調整:因為一些偶發情況,如線上用戶參與度不高,及時調整用戶參與門檻等(當然也可以在開發前把所有情況考慮到位,但是為了小概率事件做大量的工作,成本過高)。研發測試心力交瘁:研發硬編碼,測試驗證復雜重復邏輯,久而久之變的愈發疲憊。時間線(多條時間線交織混亂)研發編排錯了再來:一般營銷類型的會涉及很多時間線,而在當前,測試一個未來要上線的具有不同時間節點屬性的活動,硬編碼時往往由研發編排時間,測試進行測試,但是當 bug 發生并打亂時間線時,就需要重新編排時間(沒有經歷過的不用太了解,后面會說)。測試并行孔融讓梨:當時間線發生沖突并有多個測試在沖突位置上并發測試,往往由測試自行協調測試順序,當一方出現問題往往導致后續測試進度不可控。其他問題依賴掛了難以為繼:測試環境為非穩定環境,一旦依賴出了問題難免影響進度,如何能做到簡單高效 mock?修復數據苦不堪言:當線上問題產生時,受影響的客戶如何快速高效的補償?

ice 的設計思想

為了方便理解,設計思路將伴隨著一個簡單的充值例子展開。

舉例

X 公司將在國慶放假期間,開展一個為期七天的充值小活動,活動內容如下:活動時間:(10.1-10.7)活動內容:充值 100 元 送 5 元余額 (10.1-10.7)充值 50 元 送 10 積分 (10.5-10.7)活動備注: 不疊加送 (充值 100 元只能獲得 5 元余額,不會疊加贈送 10 積分)簡單拆解一下,想要完成這個活動,我們需要開發如下模塊:

9084c582-16c5-11ed-ba43-dac502259ad0.png

如上圖,當用戶充值成功后,會產生對應充值場景的參數包裹 Pack (類 Activiti/Drools 的 Fact),包裹里會有充值用戶的 uid,充值金額 cost,充值的時間 requestTime 等信息。我們可以通過定義的 key,拿到包裹中的值 (類似 map.get (key))。模塊怎么設計無可厚非,重點要講的是后面的怎么編排實現配置自由,接下來將通過已有的上述節點,講解不同的規則引擎在核心的編排上的優缺點,并比較 ice 是怎么做的。

流程圖式實現

類 Activiti、 Flowable 實現:

909baf9a-16c5-11ed-ba43-dac502259ad0.png

流程圖式實現,應該是我們最常想到的編排方式了~看起來非常的簡潔易懂,通過特殊的設計,如去掉一些不必要的線,可以把 UI 做的更簡潔一些。但由于有時間屬性,其實時間也是一個規則條件,加上之后就變成了:

90b2cab8-16c5-11ed-ba43-dac502259ad0.png

看起來也還好

執行樹式實現

類 Drools 實現 (When X Then Y):

90c6ae70-16c5-11ed-ba43-dac502259ad0.png

這個看起來也還好,再加上時間線試試:

90df289c-16c5-11ed-ba43-dac502259ad0.png

依舊比較簡潔,至少比較流程圖式,我會比較愿意修改這個。

計劃永遠趕不上變化

上面兩種方案的優點在于,可以把一些零散的配置結合業務很好的管理了起來,對配置的小修小改,都是信手拈來,但是真實的業務場景,可能還是要錘爆你,有了靈活的變動,一切都不一樣了。

理想

不會變的,放心吧,就這樣,上

現實

①充值 100 元改成 80 吧,10 積分變 20 積分吧,時間改成 10.8 號結束吧(微微一笑,畢竟我費了這么大勁搞規則引擎,終于體現到價值了!)②用戶參與積極性不高啊,去掉不疊加送吧,都送(稍加思索,費幾個腦細胞挪一挪還是可以的,怎么也比改代碼再上線強吧!)③5 元余額不能送太多,設置個庫存 100 個吧,對了,庫存不足了充 100 元還是得送 10 積分的哈(卒… 早知道還不如硬編碼了)以上變動其實并非看起來不切實際,畢竟真實線上變動比這離譜的多的是,流程圖式和執行樹式實現的主要缺點在于,牽一發而動全身,改動一個節點需要瞻前顧后,如果考慮不到位,很容易弄錯,而且這還只是一個簡單的例子,現實的活動內容要比這復雜的多的多,時間線也是很多條,考慮到這,再加上使用學習框架的成本,往往得不償失,到頭來發現還不如硬編碼。怎么辦?

讓我們看看 ice 是怎么做的?

引入關系節點

關系節點為了控制業務流轉AND所有子節點中,有一個返回 false 該節點也將是 false,全部是 true 才是 true,在執行到 false 的地方終止執行,類似于 Java 的 &&ANY所有子節點中,有一個返回 true 該節點也將是 true,全部 false 則 false,在執行到 true 的地方終止執行,類似于 Java 的 ||ALL所有子節點都會執行,有任意一個返回 true 該節點也是 true,沒有 true 有一個節點是 false 則 false,沒有 true 也沒有 false 則返回 none,所有子節點執行完畢終止NONE所有子節點都會執行,無論子節點返回什么,都返回 noneTRUE所有子節點都會執行,無論子節點返回什么,都返回 true,沒有子節點也返回 true (其他沒有子節點返回 none)

引入葉子節點

葉子節點為真正處理的節點Flow一些條件與規則節點,如例子中的 ScoreFlowResult一些結果性質的節點,如例子中的 AmountResult,PointResultNone一些不干預流程的動作,如裝配工作等,如下文會介紹到的 TimeChangeNone有了以上節點,我們要怎么組裝呢?

90ed85a4-16c5-11ed-ba43-dac502259ad0.png

如上圖,使用樹形結構 (對傳統樹做了鏡像和旋轉),執行順序還是類似于中序遍歷,從 root 執行,root 是個關系節點,從上到下執行子節點,若用戶充值金額是 70 元,執行流程:[ScoreFlow-100:false]→[AND:false]→[ScoreFlow-50:true]→[PointResult:true]→[AND:true]→[ANY:true]這個時候可以看到,之前需要剝離出的時間,已經可以融合到各個節點上了,把時間配置還給節點,如果沒到執行時間,如發放積分的節點 10.5 日之后才生效,那么在 10.5 之前,可以理解為這個節點不存在。

變化的靈活快速應對

對于①直接修改節點配置就可以對于②直接把 root 節點的 ANY 改成 ALL 就可以 (疊加送與不疊加送的邏輯在這個節點上,屬于這個節點的邏輯就該由這個節點去解決)對于③由于庫存的不足,相當于沒有給用戶發放,則 AmountResult 返回 false,流程還會繼續向下執行,不用做任何更改再加一個棘手的問題,當時間線復雜時,測試工作以及測試并發要怎么做?一個 10.1 開始的活動,一定是在 10.1 之前開發上線完畢,比如我在 9.15 要怎么去測試一個 10.1 開始的活動?在 ice 中,只需要稍微修改一下:

9106a1e2-16c5-11ed-ba43-dac502259ad0.png

如圖,引入一個負責更改時間的節點 TimeChangeNone (更改包裹中的 requestTime),后面的節點執行都是依賴于包裹中的時間即可,TimeChangeNone 類似于一個改時間的插件一樣,如果測試并行,那就給多個測試每人在自己負責的業務上加上改時間插件即可。

ice 的特性

為什么這么拆解呢?為什么這樣就能解決這些變動與問題呢?其實,就是使用樹形結構解耦,流程圖式和執行樹式實現在改動邏輯的時候,不免需要瞻前顧后,但是 ice 不需要,ice 的業務邏輯都在本節點上,每一個節點都可以代表單一邏輯,比如我改不疊加送變成疊加送這一邏輯就只限制在那個 ANY 節點邏輯上,只要把它改成我想要的邏輯即可,至于子節點有哪些,不用特別在意,節點之間依賴包裹流轉,每個節點執行完的后續流程不需要自己指定。因為自己執行完后的執行流程不再由自己掌控,就可以做到復用:

91148d2a-16c5-11ed-ba43-dac502259ad0.png

如圖,參與活動這里用到的 TimeChangeNone,如果現在還有個 H5 頁面需要做呈現,不同的呈現也與時間相關,怎么辦?只需要在呈現活動這里使用同一個實例,更改其中一個,另一個也會被更新,避免了到處改時間的問題。同理,如果線上出了問題,比如 sendAmount 接口掛了,由于是 error 不會反回 false 繼續執行,而是提供了可選策略,比如將 Pack 以及執行到了哪個節點落盤起來,等到接口修復,再繼續丟進 ice 重新跑即可 (由于落盤時間是發生問題時間,完全不用擔心活動結束了的修復不生效問題),同樣的,如果是不關鍵的業務如頭像服務掛了,但是依然希望跑起來,只是沒有頭像而已,這樣可以選擇跳過錯誤繼續執行。這里的落盤等規則不細展開描述。同樣的原理也可以用在 mock 上,只需要在 Pack 中增加需要 mock 的數據,就可以跑起來。

引入前置節點

9120a48e-16c5-11ed-ba43-dac502259ad0.png

上面的邏輯中可以看到有一些 AND 節點緊密綁定的關系,為了視圖與配置簡化,增加了前置 (forward) 節點概念,當且僅當前置節點執行結果為非 false 時才會執行本節點,語義與 AND 相連的兩個節點一致。

審核編輯:彭靜
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 模塊
    +關注

    關注

    7

    文章

    2731

    瀏覽量

    47665
  • 編碼
    +關注

    關注

    6

    文章

    957

    瀏覽量

    54915
  • 開源
    +關注

    關注

    3

    文章

    3398

    瀏覽量

    42653
  • 數據分析
    +關注

    關注

    2

    文章

    1460

    瀏覽量

    34120

原文標題:開源規則引擎-ice(致力于解決靈活繁復的硬編碼問題)

文章出處:【微信號:OSC開源社區,微信公眾號:OSC開源社區】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    請問地震勘探上ADS1282與ADS1255相比有什么優缺點

    請問地震勘探上ADS1282與ADS1255相比有什么優缺點
    發表于 11-22 07:06

    不同類型adc的優缺點分析

    ADC(模數轉換器)是將模擬信號轉換為數字信號的電路,根據轉換原理和應用需求的不同,ADC可以分為多種類型,每種類型都有其獨特的優缺點,以下是對不同類型ADC的優缺點分析: 逐次逼近型ADC(SAR
    的頭像 發表于 11-19 16:58 ?1153次閱讀

    開環和閉環功放的區別,優缺點,應用場合有什么不同?

    問下TI的工程師,開環和閉環功放的區別,優缺點,應用場合有什么不同?請解釋下,謝謝!
    發表于 11-04 06:33

    電壓跟隨器優缺點有哪些

    電壓跟隨器,也稱為電壓緩沖器或緩沖放大器,是一種特殊的放大器電路,其核心特點是輸出電壓緊密跟隨輸入電壓的變化,同時保持兩者之間的高度一致性。這種電路電子設計中具有廣泛的應用,但也存在一些固有的優缺點
    的頭像 發表于 09-24 11:25 ?687次閱讀

    雪崩晶體管有哪些優缺點

    雪崩晶體管作為一種特殊的半導體器件,電子領域具有其獨特的優缺點
    的頭像 發表于 09-23 18:05 ?353次閱讀

    內存控制器有哪些優缺點

    內存控制器作為計算機系統中的核心組件之一,提高系統性能、優化數據傳輸以及確保數據穩定性方面發揮著至關重要的作用。然而,它同樣存在一些不可忽視的優缺點
    的頭像 發表于 09-04 14:20 ?394次閱讀

    運放恒流源有哪些優缺點

    運放恒流源,即利用運算放大器(Operational Amplifier,簡稱運放)構成的恒流源電路,具有一系列獨特的優點和缺點。以下是對其優缺點的詳細分析。
    的頭像 發表于 08-28 10:18 ?1378次閱讀

    GaN HEMT有哪些優缺點

    GaN HEMT(氮化鎵高電子遷移率晶體管)作為一種先進的功率半導體器件,電力電子、高頻通信、汽車電子等多個領域展現出了顯著的優勢,但同時也存在一些缺點。以下是對GaN HEMT優缺點的詳細分析:
    的頭像 發表于 08-15 11:09 ?1640次閱讀

    AI大模型與小模型的優缺點

    人工智能(AI)的廣闊領域中,模型作為算法與數據之間的橋梁,扮演著至關重要的角色。根據模型的大小和復雜度,我們可以將其大致分為AI大模型和小模型。這兩種模型定義、優缺點及應用場景上存在著顯著的差異。本文將從多個維度深入探討A
    的頭像 發表于 07-10 10:39 ?3306次閱讀

    各種電機的類型、優缺點及應用

    電機作為現代工業和科技領域的核心動力裝置,其種類繁多,各具特色,廣泛應用于各個領域。本文將對幾種常見的電機類型進行詳細介紹,包括其優缺點以及主要應用領域,以便讀者能夠更好地了解和選擇適合自己的電機。
    的頭像 發表于 06-04 16:52 ?3715次閱讀

    nbiot和lora的優缺點是什么?

    nbiot和lora的優缺點
    發表于 06-04 06:37

    日本大帶寬服務器優缺點分析

    日本大帶寬服務器是很多用戶的選擇,那么日本大帶寬服務器優缺點都是什么?Rak部落小編為您整理發布日本大帶寬服務器優缺點分析。
    的頭像 發表于 03-22 10:08 ?505次閱讀

    儲能元件的分類和優缺點

    常見的PCS儲能用的是電池,有磷酸鐵鋰,鋰電池等材料,但是也有用電容儲能的,比如用無極性大電容和超級法拉電容的。 1、請問用電池儲能和電容儲能那種效率更高?兩者各有什么優缺點? 2、儲能過程中,儲
    發表于 03-11 23:03

    數組和鏈表在內存中的區別 數組和鏈表的優缺點

    數組和鏈表在內存中的區別 數組和鏈表的優缺點? 數組和鏈表是常見的數據結構,用于組織和存儲數據。它們在內存中的存儲方式以及優缺點方面存在一些顯著的差異。本文將詳細探討這些差異以及它們的優缺點。 1.
    的頭像 發表于 02-21 11:30 ?1115次閱讀

    變頻器旁路安裝的優缺點

    變頻器旁路安裝的優缺點及其影響因素 隨著科技的不斷發展,變頻器成為了工業和生活中不可或缺的設備。然而,變頻器的安裝和應用過程中,是否選擇進行旁路安裝一直是一個爭論的焦點。旁路安裝是指將變頻器設備
    的頭像 發表于 02-01 14:48 ?1776次閱讀
    主站蜘蛛池模板: 中文字幕亚洲综合小综合在线 | 玖玖爱这里只有精品视频 | 国产精品久久久久久免费字体 | 久久视频这有精品63在线国产 | 777米奇影院第七色色 | 亚洲精品tv久久久久久久久久 | 97夜夜澡人人爽人人模人人喊 | 最新国产三级在线不卡视频 | 任你躁国语自产二区在线播放 | 国产精品网红女主播久久久 | 国内精品久久久久久久999下 | 浴室里强摁做开腿呻吟的漫画男男 | 国产免费播放一区二区三区 | 亚洲爆乳少妇精品无码专区 | 老师的玉足高跟鞋满足我 | 翁公吮她的花蒂和奶水 | 人妻插B视频一区二区三区 人妻 中文无码 中出 | 手机在线亚洲日韩国产 | 好大好硬好爽好深好硬视频 | 双性诱受灌满哭求饶BL | 久久亚洲精品AV成人无 | 少妇伦子伦情品无吗 | 欧美黑人巨大videos免费 | 亚洲成片在线看 | 久久九九有精品国产23百花影院 | 4k岛国精品午夜高清在线观看 | 91久久精品一区二区三区 | 日韩欧美一区二区三区在线 | 一道精品视频一区二区三区 | 成人网站国产在线视频内射视频 | 人妻体体内射精一区二区 | 东京热百度影音 | 99热在线精品免费全部my | 邻家美姨在线观看全集免费 | 丰满艳妇亲伦 | 曰本aaaaa毛片午夜网站 | 成人免费观看在线视频 | 亚洲薄码区| 国产精品久久久久久亚洲毛片 | 东京热影院 | 嘟嘟嘟WWW免费高清在线中文 |