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

来源: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
  • 概述:這個WPF項目通過XAML繪製汽車動態速度表盤,實現了0-300的速度刻度,包括數字、指針,並通過定時器模擬速度變化,展示了動態效果。詳細實現包括界面設計、刻度繪製、指針角度計算等,通過C#代碼與XAML文件結合完成。 新建 WPF 項目: 在 Visual Studio 中創建一個新的 WP ...
  • 概述:在WPF中使用`WpfAnimatedGif`庫展示GIF動畫,首先確保全裝了該庫。通過XAML設置Image控制項,指定GIF路徑,然後在代碼中使用庫提供的方法實現動畫控制。這簡化了在WPF應用中處理GIF圖的過程,提供了方便的介面來管理動畫播放和暫停。 當使用 WpfAnimatedGif  ...
  • 您是否曾經訪問過一個網站,它需要很長時間載入,最終你敲擊 F5 重新載入頁面。 即使用戶刷新了瀏覽器取消了原始請求,而對於伺服器來說,API也不會知道它正在計算的值將在結束時被丟棄,刷新五次,伺服器將觸發 5 個請求。 為瞭解決這個問題,ASP.NET Core 為 Web 伺服器提供了一種機制,就 ...
  • 本章將和大家分享如何通過 Elasticsearch 實現自動補全查詢功能。 一、自動補全-安裝拼音分詞器 1、自動補全需求說明 當用戶在搜索框輸入字元時,我們應該提示出與該字元有關的搜索項,如圖: 2、使用拼音分詞 要實現根據字母做補全,就必須對文檔按照拼音分詞。在 GitHub 上恰好有 Ela ...
  • using System; using System.Collections.Generic; using System.IO; using System.Linq; using System.Text; using System.Windows.Forms; namespace OOP { pub ...
  • 概述:以上內容詳細介紹了在C#中如何從另一個線程更新GUI,包括基礎功能和高級功能。對於WinForms,使用`Control.Invoke`;對於WPF,使用`Dispatcher.Invoke`。高級功能使用`SynchronizationContext`實現線程間通信,確保清晰、可讀性高的代碼 ...
  • Nuget包 Microsoft.Extensions.Telemetry.Abstractions 包含的新的日誌記錄source generator,它支持使用[LogProperties]將整個對象作為State與日誌一起記錄。 我將展示一種方法來控制如何使用[LogProperties]對象 ...
  • 支持.Net/.Net Core/.Net Framework,可以部署在Docker, Windows, Linux, Mac。 常見的ORM技術(比如:Entity Framework,Dapper,SqlSugar,NHibernate,等…),它們不是在做Sql語句的程式化變種,就是在做Sq ...
  • 一、引言 在現代應用程式開發中,尤其是在涉及I/O操作(如網路請求、文件讀寫等)時,非同步編程成為了提高性能和用戶體驗的關鍵技術。C#作為.NET框架下的主流開發語言,提供了強大的非同步編程支持,通過async/await關鍵字,可以讓開發者以同步的方式編寫非同步代碼,極大地簡化了非同步編程的複雜性。本文將 ...
  • 一、引言 在.NET開發中,操作Office文檔(特別是Excel和Word)是一項常見的需求。然而,在伺服器端或無Microsoft Office環境的場景下,直接使用Office Interop可能會面臨挑戰。為瞭解決這個問題,開源庫NPOI應運而生,它提供了無需安裝Office即可創建、讀取和 ...