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

来源: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
  • Timer是什麼 Timer 是一種用於創建定期粒度行為的機制。 與標準的 .NET System.Threading.Timer 類相似,Orleans 的 Timer 允許在一段時間後執行特定的操作,或者在特定的時間間隔內重覆執行操作。 它在分散式系統中具有重要作用,特別是在處理需要周期性執行的 ...
  • 前言 相信很多做WPF開發的小伙伴都遇到過表格類的需求,雖然現有的Grid控制項也能實現,但是使用起來的體驗感並不好,比如要實現一個Excel中的表格效果,估計你能想到的第一個方法就是套Border控制項,用這種方法你需要控制每個Border的邊框,並且在一堆Bordr中找到Grid.Row,Grid. ...
  • .NET C#程式啟動閃退,目錄導致的問題 這是第2次踩這個坑了,很小的編程細節,容易忽略,所以寫個博客,分享給大家。 1.第一次坑:是windows 系統把程式運行成服務,找不到配置文件,原因是以服務運行它的工作目錄是在C:\Windows\System32 2.本次坑:WPF桌面程式通過註冊表設 ...
  • 在分散式系統中,數據的持久化是至關重要的一環。 Orleans 7 引入了強大的持久化功能,使得在分散式環境下管理數據變得更加輕鬆和可靠。 本文將介紹什麼是 Orleans 7 的持久化,如何設置它以及相應的代碼示例。 什麼是 Orleans 7 的持久化? Orleans 7 的持久化是指將 Or ...
  • 前言 .NET Feature Management 是一個用於管理應用程式功能的庫,它可以幫助開發人員在應用程式中輕鬆地添加、移除和管理功能。使用 Feature Management,開發人員可以根據不同用戶、環境或其他條件來動態地控制應用程式中的功能。這使得開發人員可以更靈活地管理應用程式的功 ...
  • 在 WPF 應用程式中,拖放操作是實現用戶交互的重要組成部分。通過拖放操作,用戶可以輕鬆地將數據從一個位置移動到另一個位置,或者將控制項從一個容器移動到另一個容器。然而,WPF 中預設的拖放操作可能並不是那麼好用。為瞭解決這個問題,我們可以自定義一個 Panel 來實現更簡單的拖拽操作。 自定義 Pa ...
  • 在實際使用中,由於涉及到不同編程語言之間互相調用,導致C++ 中的OpenCV與C#中的OpenCvSharp 圖像數據在不同編程語言之間難以有效傳遞。在本文中我們將結合OpenCvSharp源碼實現原理,探究兩種數據之間的通信方式。 ...
  • 一、前言 這是一篇搭建許可權管理系統的系列文章。 隨著網路的發展,信息安全對應任何企業來說都越發的重要,而本系列文章將和大家一起一步一步搭建一個全新的許可權管理系統。 說明:由於搭建一個全新的項目過於繁瑣,所有作者將挑選核心代碼和核心思路進行分享。 二、技術選擇 三、開始設計 1、自主搭建vue前端和. ...
  • Csharper中的表達式樹 這節課來瞭解一下表示式樹是什麼? 在C#中,表達式樹是一種數據結構,它可以表示一些代碼塊,如Lambda表達式或查詢表達式。表達式樹使你能夠查看和操作數據,就像你可以查看和操作代碼一樣。它們通常用於創建動態查詢和解析表達式。 一、認識表達式樹 為什麼要這樣說?它和委托有 ...
  • 在使用Django等框架來操作MySQL時,實際上底層還是通過Python來操作的,首先需要安裝一個驅動程式,在Python3中,驅動程式有多種選擇,比如有pymysql以及mysqlclient等。使用pip命令安裝mysqlclient失敗應如何解決? 安裝的python版本說明 機器同時安裝了 ...