寫完這款工作流組件,我的髮際線又高了...

来源:https://www.cnblogs.com/StarbucksBoy/archive/2023/02/03/17088622.html
-Advertisement-
Play Games

前段時間因業務需要完成了一個工作流組件的編碼工作。藉著這個機會跟大家分享一下整個創作過程,希望大家喜歡,組件暫且命名為"easyFlowable"。 接下來的文章我將從什麼是工作流、為什麼要自研這個工作流組件、架構設計三個維度跟大家來做個整體介紹。 ...


大家好,我是陶朱公Boy(一個認真生活總想超越自己的程式員!)。

前言

前段時間因業務需要完成了一個工作流組件的編碼工作。藉著這個機會跟大家分享一下整個創作過程,希望大家喜歡,組件暫且命名為"easyFlowable"
接下來的文章我將從什麼是工作流為什麼要自研這個工作流組件架構設計個維度跟大家來做個整體介紹。

什麼是工作流

定義:

工作流(Workflow)是對工作流程及其各操作步驟之間業務規則的抽象、概括描述。工作流建模,即將工作流程中的工作如何前後組織在一起的邏輯和規則,在電腦中以恰當的模型表達並對其實施計算。工作流要解決的主要問題是:為實現某個業務目標,利用電腦在多個參與者之間按某種預定規則自動傳遞文檔、信息或者任務                                                                                                                                                                                                                                               --摘自維基百科

簡單點說,我認為工作流就是對業務的流程化抽象。WFMC給出了工作流參考模型如下:

為什麼稱之為“流”,則是各個節點通過內外部驅動觸發引起節點的推進,形成一個流式的狀態達到業務終點。比如一次用戶查看淘寶商品的費用、一次支付成功後的權益開通、一次用戶註冊、一次調度任務的運行等,都是可以是一個工作流。

適用場景:

工作流引擎不僅能較好支撐大家熟悉的比如OA辦公審批或單據審批,幾乎所有涉及到業務流轉、多人按流程完成工作的場景背後都可以通過工作流引擎作為支撐。
基於工作流引擎,可以搭建客戶關係管理系統(CRM)、運輸管理系統(TMS)、倉儲管理系統(WMS)、財務費用系統等多種複雜業務系統。
對於達到一定規模的企業,良好的 BPM(業務流程管理,Business Process Management)體系可以支持創建公司內橫跨不同部門的複雜業務流程,既提高工作效率、又可推動企業規範化發展。

關於為什麼要造輪子

目前市場上比較有名的開源工作流程引擎有osworkflow、jbpm、activiti、flowable、camunda等,國內有Liteflow。(Jbpm4、Activiti、Flowable、camunda四個框架同宗同源,祖先都是Jbpm4)。

這些工作流組件功能豐富且強大,支持流程可視化、業務流程可編排、狀態持久化和自動重試等。

但我們前期需求實在太簡單了,只需要用到業務可編排能力,其他能力暫時用不上。經過綜合考慮之後決定還是自己簡單的實現一個,也方便將來的可定製化。

架構設計

▲功能說明

流程編排

上文也提到我們最主要的核心是流程可編排能力。所以前期需要有所謂的"規則"來支撐,通過規則來詮釋上圖的語義。(不同的外部意見,不同的操作節點)
規則的實現可以是資料庫表也可以是外部文件比如json、xml、yaml等。我們採用了比較容易實現的即資料庫方案,如圖:

 

▲業務架構

組件接入請求後(支持http和rpc方式)首先需要執行一個route組件,該route組件的核心職責是根據配置在資料庫中的編排規則,根據外部條件結合process表(詳見ER圖說明)來動態查找待執行的目標節點和下一個即將執行的節點等信息。
route過後會經過build組件構建,build的核心是進行數據的構建、封裝成XXComponet對象最終執行目標組件內的業務邏輯。
組件關於流程狀態(流程狀態、申請狀態)的實現採用了阿裡開源的狀態機方案——cola-statemachine(關於此狀態機的更多信息大家可以查閱一下我之前寫的博文,這裡就不過多贅述。 github上fork2.4k,star8.7k的這款狀態機,原來長這樣!)。

▲類圖

 

時序圖

業務方通過http或rpc方式接入我們的工作流組件,工作流組件首先根據外部條件結合process表定址得到目標節點和下一個待執行節點,經過build組件構建後得到可執行的目標Component對象,最後執行其process方法完成節點對應的原子業務操作!

▲ER圖

整個ER圖細分為:

flow_config

flow_node_config

flow_node_chain_config

flow_node_process

flow_node_process_log

這五張表(XXconfig結尾的表是後臺配置表,需要提前定義)。

flow_config:自定義一條流程配置項,有一個status欄位可以支持停用、啟用流程操作。
flow_node_config:自定義一條節點配置項,我們業務層面分離的一個又一個處理邏輯,在這裡抽象為node的概念。
flow_node_chain_config:這張表是所謂的”規則編排表“。需要配置基於哪個flow_id在滿足什麼外部條件下(比如操作意見:通過或不通過)配置各個node和下一個node的配置(外部條件不同nextNode不同)。
給大家舉個例子:

 

大家看下上述截圖中的標紅兩條數據,分別代表著某個目標組件在滿足外部條件1的情況下下一個節點是7,在滿足了另一個外部條件2的情況下下一個節點15。

flow_node_process:流程運行時表。這張表也很重要它表達的是某一次具體的業務流程單(請求的時候必須傳遞一個唯一的流程單號的入參,代辦某個具體的流程申請)的運行態數據(申請狀態,流程狀態)。

通過這些狀態能知道某流程單號實際的運行情況(運行到具體哪個節點了,下一個待執行的節點是什麼)等。流程的定址是需要根據此表的數據來進行下去。

flow_node_process_log:這張表顧名思義是日誌表,每一個流程單的運行經過各個節點,運行完後(無論成功或失敗)最終都會落一條日誌記錄數據。

▲關於開源:

組件作者還在整理中,先貼下github地址:https://github.com/TaoZhuGongBoy/easyFlowable。(會在近期完全開放,敬請期待)

總結

好了,這款組件的介紹到此已接近尾聲,讓我們一起來做個總結:
首先在文章開始出我給大家先簡單的介紹了一下工作流的定義,讓大家對它有一定的瞭解。(回答了是什麼和適用場景問題)
然後我也解釋了我們為什麼自研這款工作流組件而不選擇開源方案的原因。
最後我花了較多篇幅給大家詳細介紹了一下這款組件的架構設計。從功能說明到業務架構圖說起,再到各個UML圖包括類圖、時序圖和數據建模ER圖。希望大家對這款組件的瞭解有所幫助。
本文完~

寫到最後

作為996的程式員,寫這篇文章基本都是利用工作日下班時間和周六周日雙休的時間才最終成稿,比較不易。   如果你看了文章之後但凡對你有所幫助或啟發,真誠懇請幫忙關註一下作者,點贊、在看此文。你的肯定與贊美是我未來創作最強大的動力,我也將繼續前行,創作出更加優秀好的作品回饋給大家,在此先謝謝大家了!

關註我

如果這篇文章你看了對你有幫助或啟發,麻煩點贊、關註一下作者。你的肯定是作者創作源源不斷的動力。

公眾號:「陶朱公Boy

裡面不僅彙集了硬核的乾貨技術、還彙集了像左耳朵耗子、張朝陽總結的高效學習方法論、職場升遷竅門、軟技能。希望能輔助你達到你想夢想之地!

公眾號內回覆關鍵字“電子書”下載pdf格式的電子書籍(JAVAEE、Spring、JVM、併發編程、Mysql、Linux、kafka、分散式等)、“開發手冊”獲取阿裡開發手冊2本、"面試"獲取面試PDF資料。


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

-Advertisement-
Play Games
更多相關文章
  • 最大公約數演算法不是很無聊,計算最大公約數是數學中一個重要的概念,可以用於判斷兩個數是否互質、求分數的約分等,在很多領域都有廣泛的應用。具體如下: 判斷兩個數是否互質:兩個數的最大公約數為1,說明這兩個數是互質的。 求分數的約分:將分子和分母的最大公約數約分掉,使得分數的值不變。 求同餘方程的最小正整 ...
  • 聲明 本文章中所有內容僅供學習交流,抓包內容、敏感網址、數據介面均已做脫敏處理,嚴禁用於商業用途和非法用途,否則由此產生的一切後果均與作者無關,若有侵權,請聯繫我立即刪除! 本文章未經許可禁止轉載,禁止任何修改後二次傳播,擅自使用本文講解的技術而導致的任何意外,作者均不負責,若有侵權,請在公眾號【K ...
  • BP(Back Propagation)演算法是一種常用的神經網路訓練演算法,主要用於識別分類和預測。常用於圖像識別、語音識別、文本分類等場景。它的原理是通過對誤差進行反向傳播來更新網路的參數,使得模型的誤差最小。BP演算法最早於1986年由Rumelhart等人提出。BP演算法適用於處理非線性問題,並且不 ...
  • 基於php大文件分片上傳至七牛雲,使用的是七牛雲js-sdk V2版本,引入js文件,配置簡單,可以暫停,暫停後支持斷點續傳(刷新、關閉頁面、重新上傳、網路中斷等情況),可以配置分片大小和分片數量,官方文檔https://developer.qiniu.com/kodo/6889/javascrip ...
  • 基於php+webuploader的大文件分片上傳,帶進度條,支持斷點續傳(刷新、關閉頁面、重新上傳、網路中斷等情況)。文件上傳前先檢測該文件是否已上傳,如果已上傳提示“文件已存在”,如果未上傳則直接上傳。視頻上傳時會根據設定的參數(分片大小、分片數量)進行上傳,上傳過程中會在目標文件夾中生成一個臨 ...
  • 背景 我們的業務共使用11台(阿裡雲)伺服器,使用SpringcloudAlibaba構建微服務集群,共計60個微服務,全部註冊在同一個Nacos集群 流量轉發路徑: nginx->spring-gateway->業務微服務 使用的版本如下: spring-boot.version:2.2.5.RE ...
  • 摘要:在jvm中有很多的參數可以進行設置,這樣可以讓jvm在各種環境中都能夠高效的運行。絕大部分的參數保持預設即可。 本文分享自華為雲社區《為什麼需要對jvm進行優化,jvm運行參數之標準參數》,作者:共飲一杯無。 我們為什麼要對jvm做優化? 在本地開發環境中我們很少會遇到需要對jvm進行優化的需 ...
  • 1 簡介 我們之前使用了dapr的本地托管模式,但在生產中我們一般使用Kubernetes托管,本文介紹如何在GKE(GCP Kubernetes)安裝dapr。 相關文章: dapr本地托管的服務調用體驗與Java SDK的Spring Boot整合 dapr入門與本地托管模式嘗試 2 安裝GKE ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...