流程編排、如此簡單-通用流程編排組件JDEasyFlow介紹

来源:https://www.cnblogs.com/Jcloud/archive/2022/11/25/16924575.html
-Advertisement-
Play Games

作者:李玉亮 JDEasyFlow是企業金融研發部自研的通用流程編排技術組件,適用於服務編排、工作流、審批流等場景,該組件已開源(https://github.com/JDEasyFlow/jd-easyflow),目前在部門的內部業務系統和科技輸出系統中廣泛應用,其他部門也有使用。 它的特點是簡單 ...


作者:李玉亮

JDEasyFlow是企業金融研發部自研的通用流程編排技術組件,適用於服務編排、工作流、審批流等場景,該組件已開源(https://github.com/JDEasyFlow/jd-easyflow),目前在部門的內部業務系統和科技輸出系統中廣泛應用,其他部門也有使用。

它的特點是簡單、靈活、易擴展,開發人員一般30分鐘可入門上手,半天可掌握其原理。它分為一個核心模塊和若幹擴展模塊,模塊之間松耦合,開發使用時可按需選擇、快速集成、漸進式應用,同時支持JSON內置規範和BPMN規範。它的實現原理也有其特色,後面有介紹。

支持的場景功能

節點流轉類型

支持順序流轉、條件流轉、迴圈流轉等。

節點功能類型

支持腳本節點、用戶節點和消息節點。

腳本節點:節點執行時運行一段代碼腳本

用戶節點:根據用戶的操作指令觸發節點執行

消息節點:接收消息後觸發節點執行

節點串並類型

支持串列執行、並行執行、串並組合執行等。

流程交互場景

支持單次交互一次執行多節點、多次交互一次執行一節點、多次交互一次執行多節點等。

子流程場景

JDEasyFlow支持子流程的場景,可將把複雜的流程節點拆分為子流程,便於業務邏輯抽象。

審批流程場景

JDEasyFlow提供了流程任務審批的能力;常用的審批、撤銷、駁回、會簽、加簽等功能都可支持;內置了簡單的動態表單。既支持從頁面發起和操作流程任務,也支持API的方式,京東OA審批系統也有對接。

功能架構

整體功能架構

JDEasyFlow的功能架構如下圖,功能模塊之間松耦合, 開發時可按需選擇、快速集成、漸進式應用最簡單的使用方式為只在業務應用端引入jar包使用流程引擎。如果需要流程可視化功能,可集成BPMN規範模塊,如果還需要流程實例持久化、流程定義持久化等更豐富功能,則可以集成其他相關模塊。

流程引擎模塊

JDEasyFlow的核心模塊,此模塊提供了基於JSON格式的JDEasyFlow規範進行流程編排的能力,其他模塊均基於該模塊擴展,相當於流程執行的發動機、CPU。該功能模塊為獨立組件,無資料庫依賴,應用中引入jar包便可使用。

BPMN規範模塊

提供了基於BPMN規範進行流程定義和可視化的能力,流程可視化基於[bpmn-js](https://bpmn.io/),其本質為提供了將BPMN格式流程定義轉換為JDEasyFlow格式的能力。該模塊為獨立組件,僅依賴流程引擎模塊,無資料庫和服務依賴,應用中引入jar包便可使用。

目前可支持常用的BPMN元素:

任務:腳本任務、用戶任務、消息任務

事件:開始事件、結束事件、消息接收事件

網關:排他網關、並行網關、包容網關

流程定義和實例管理模塊

流程定義模塊支持流程定義的中心化、版本化管理,流程實例模塊支持流程實例的持久化和生命周期管理。該功能依賴資料庫,有服務端和ERP管理端。

任務/審批模塊

支持任務生成、任務分配等功能,常用的審批、撤銷、駁回、會簽、加簽等功能都可支持。該功能依賴資料庫,有服務端和ERP管理端。

系統架構

整體系統架構

JDEasyFlow的完整系統架構如下,主要有三個端:業務應用端、流程服務端、流程管理端,三個端可部署在單體應用中,也可分開部署。

中間件依賴

· 關係型資料庫(如Mysql)

· 緩存(如Redis或R2M)

· 服務通訊框架(如Java API調用或Http調用或JSF調用)

資料庫數據模型比較簡單清晰,見下圖:

性能說明

· 如果僅是服務編排場景,則流程的執行僅依賴記憶體和CPU,並且是在流程客戶端執行,性能上依賴於客戶端伺服器的性能,普通筆記本實測1秒可執行一個流程請求的1w+個節點,1秒可執行1萬+次含1個節點的流程請求

· 如果需要流程狀態管理和流程持久化功能,流程引擎在執行時會到流程服務端查詢和保存流程實例和流程節點的狀態,性能上主要依賴於資料庫的查詢和插入效率

· 對於流程任務審批功能,流程的任務審批流轉是在服務端執行,一方面取決於流程服務端的計算性能,另一方面同樣取決於資料庫的查詢和插入效率

可伸縮性說明

· 流程引擎屬於無狀態,可隨應用實例線性伸縮

· 流程服務端應用實例支持線性擴展

· 流程資料庫可通過分庫分表的方式支持大數據量的增長

實踐建議

在具體實踐中,建議部署統一的流程中心(見下圖),對流程定義統一管理。各系統的應用只需集成流程客戶端jar包進行流程節點開發和流程調用便可。如果系統只使用任務審批的功能,則只需要通過API和消息與流程中心交互便可。

使用示例

流程引擎使用示例

在源碼的test目錄下有quickstart測試用例(easyflow\easyflow-flow\src\test\java\com\jd\easyflow\flow\quickstart\QuickStartTest.java),可直接運行或調試以瞭解使用方式和運行原理。具體實踐步驟如下:

1、代碼中引入easyflow-flow jar包,以maven為例:

<dependency>
        <groupId>com.jd.easyflow</groupId>
        <artifactId>easyflow-flow</artifactId>
        <version>{替換為最新版本}</version>
</dependency>


2、編寫流程定義文件,以node001->node002→node003的執行順序為例:

{"id": "quickstart_001", "name": "Quick Start 001",
"nodes": [
  {"id": "node001","name": "Node001","action": {"createExp": "new com.jd.easyflow.flow.quickstart.QuickStart001Node01Action()"},"start": true,"post": {"to": "node002"}},
  {"id": "node002","name": "Node002","action": {"createExp": "new com.jd.easyflow.flow.quickstart.QuickStart002Node01Action()"},"post": {"to": "node003"}},
  {"id": "node003","name": "Node003","action": {"createExp": "new com.jd.easyflow.flow.quickstart.QuickStart003Node01Action()"}}
]
}


其中QuickStart001Node01Action等為java節點動作類。完整的流程定義配置項可見: https://github.com/JDEasyFlow/jd-easyflow/wiki/Flow-engine-usage (公網)

3、編寫應用啟動時載入流程引擎的代碼

   FlowEngineImpl flowEngine = new FlowEngineImpl();
   flowEngine.setFlowPath("classpath:flow/quickstart/quickstart_001.json");
   flowEngine.init();


Spring環境可直接定義FlowEngineImpl bean.

4、編寫具體流程調用執行的代碼

    FlowParam param = new FlowParam("quickstart_001");
    FlowResult result = flowEngine.execute(param);


完整測試用例的執行結果列印如下:

[main           ] INFO FlowEngineImpl         - Start parsing definition files:easyflow-flow/target/test-classes/flow/quickstart/quickstart_001.json
[main           ] INFO FlowEngineImpl         - SART EXECUTE FLOW, flowId:quickstart_001 nodeIds:null
[main           ] INFO BaseFlowRunner         - EXECUTE NODE:node001
[main           ] INFO QuickStart001Node01Action - Execute Node 001
[main           ] INFO BaseFlowRunner         - NEXT NODES:node002
[main           ] INFO BaseFlowRunner         - EXECUTE NODE:node002
[main           ] INFO QuickStart002Node01Action - Execute Node 002
[main           ] INFO BaseFlowRunner         - NEXT NODES:node003
[main           ] INFO BaseFlowRunner         - EXECUTE NODE:node003
[main           ] INFO QuickStart003Node01Action - Execute Node 003
[main           ] INFO BaseFlowRunner         - NEXT NODES:
[main           ] INFO QuickStartTest         - Execute finish, current node is:node003


BPMN模塊使用示例

打開easyflow-flow-bpmn/BPMNDesigner.html流程設計器. 點擊導入按鈕,導入easyflow-flow-bpmn/src/test/resources/flow/quickstart/quickstart_001.bpmn文件,可在設計器中看到和以上JSON定義等價的BPMN流程定義.

代碼集成使用時只需要將FlowEngineImpl的flowParser設置為BpmnFlowParser.

更多

以上只是流程引擎和BPMN模塊的簡單使用示例,JDEasyFlow還包含其他模塊、可支持很多的配置項和使用場景,更多使用可見最後的對接使用介紹.

實現原理

目前市面上的流程編排組件基本都是基於圖(邊和頂點)結構的,而本組件是參考了電腦指令執行模型而實現,借鑒了程式計數器的實現原理,引擎內部通過類似程式計數器(PC)的待執行節點棧來維護後繼節點;可以理解為是一種高級業務編程語言,它同時也是圖靈完備的。

流程引擎核心模型名詞只有一個:節點(Node),節點的功能為執行邏輯並輸出後續節點 。

開發態可定義有限的節點,通過每個節點與其後續節點連接形成有向圖;運行態按規則邏輯進行節點流轉,支持並行執行,支持順序、條件或迴圈,支持fork-join。

概念:

流程:一個業務流程的抽象

節點:流程的組成單位,一個節點能夠執行節點動作同時可返回後繼節點

節點內部構件:

節點內部構件的組成是可自定義的,流程引擎提供了預設實現,其內部構件包括了前處理器(PreHandler)、節點動作(NodeAction)、後處理器(PostHandler)

前處理器:判斷該節點是否可以執行動作

節點動作:真實的業務功能處理

後處理器:負責計算後續節點

流程引擎執行邏輯

流程引擎有一個或多個流程觸發節點,流程觸發後執行如下邏輯:

1. 初始化流程上下文

2. 得到流程起始節點ID,放入執行棧

3. 如果執行棧為空,則返回,否則執行當前節點

  1. 預檢查

  2. 執行Action

  3. 計算後繼節點ID並返回

4. 將後繼節點放入執行棧,從棧中取出待執行節點,跳到第3步

因此JDEasyFlow整體的特色為簡單

• 模型簡單:核心模型概念就是節點的流轉

• 擴展簡單:提供了監聽器、過濾器功能,方便橫向切麵;節點支持自定義實現

• 定義簡單:只需要通過JSON進行節點流轉邏輯配置便可,也支持BPMN格式

• 運行簡單:代碼調用流程引擎,傳入流程ID和業務參數便可

• 使用簡單:引入組件包便可使用,比較輕量

適用場景和對接使用說明

適用場景

理論上JDEasyFlow可滿足任何流程場景,它主要可解決三類問題:

流程可編排:將業務流程抽象為軟體流程,保證軟體是現實的真實反映;不同場景可定義不同流程,且流程易修改

功能松耦合:將業務節點抽象為軟體流程節點,一方面實現功能的松耦合,另一方面實現節點的可復用

流程可視化:所見即所得,方便業務產品人員和軟體研發人員基於同一語言的交流,也便於流程監控

在實際軟體系統開發過程中,如果有如下訴求,可考慮使用流程編排:

• 業務流程是有明顯的多個節點組成

• 希望流程可靈活變更

• 業務流程級別比程式流程高一層,在編程語言級別難以聚合和治理(如一個流程即需要前臺操作,又有外系統參與,又有後臺操作,在實現上入口分散)

對接使用

JDEasyFlow的所有文檔可見: https://github.com/JDEasyFlow/jd-easyflow/wiki (公網)

歡迎大家對接使用,有相關使用問題可聯繫: [email protected]


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 字元設備是按照位元組流進行讀寫操作的設備,讀寫數據是分先後順序的。常見的點燈、按鍵、 IIC、 SPI和LCD 等都是字元設備 。 字元設備驅動開發步驟: 總體思路: 定義並初始化一個字元設備 -1、定義一個字元設備—>struct cdev 2、定義並初始化字元設備的文件操作集—>struct fi ...
  • 使用的MCU型號為 AIR32F103CCT6. 通過工作機制和示例代碼, 說明如何使用AIR32自帶的記憶體實現簡單的語音錄製和播放功能, 以及使用 ADPCM 對音頻數據進行壓縮, 提高錄製時長. 通過這些機制, 可以快速擴充為實用的錄製設備, 例如外掛I2C或SPI存儲, 或提升無線傳輸的音質,... ...
  • Python基礎之MySQL資料庫 一、SQL語句常用查詢方法 前期數據準備 ​ 為了更加直觀的展示、演示SQL語句查詢關鍵字,需導入下列表格與記錄(數據) ​ 模擬公司,導入創建公司員工表,表內包含:ID、姓名、年齡、工作時間、崗位 創建人員表格: create table emp( id int ...
  • 在 4.2 版本及更高版本中,MongoDB 提供了事務的支持,並且在其是分散式資料庫的基礎上,提供了支持跨多個操作、集合、資料庫、文檔和分片的 ACID 事務。 ...
  • 一、什麼是數據湖? 在探討數據湖技術或如何構建數據湖之前,我們需要先明確,什麼是數據湖? 數據湖的起源,應該追溯到2010年10月。基於對半結構化、非結構化存儲的需求,同時為了推廣自家的Pentaho產品以及Hadoop,2010年Pentaho的創始人兼CTO James Dixon首次提出了數據 ...
  • 華為開發者大會2022(HDC)上,HMS Core手語數字人以全新形象亮相,併在直播中完成了長達3個多小時的實時手語翻譯,向線上線下超過一千萬的觀眾提供了專業、實時、準確的手語翻譯服務,為聽障人士提供了無障礙參會體驗。面對專業性強且辭彙量大的科技大會,HMS Core手語數字人是如何準確且流暢地打 ...
  • vuex是大家使用vue時大多數都會選擇的,但是當頁面刷新之後vuex數據會丟失,下麵這篇文章主要給大家介紹了關於vuex頁面刷新數據丟失問題的四種解決方式,需要的朋友可以參考下 為什麼說刷新頁面vuex的數據會丟失 刷新頁面vuex的數據會丟失屬於正常現象,因為JS的數據都是保存在瀏覽器的堆棧記憶體 ...
  • 前言: 從今天開始來和大家一起學習 vue3 相信大家都不陌生,已經火了一段時間了,但是還是有不少人沒有學習,那就跟著六扇老師來簡單的入個門 廢話不多說,來開始今天的學習 Vue3 簡介: 2020年,9月,18日,Vue.js發佈3.0版本,耗時兩年多,2600+次提交,99位貢獻值 github ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...