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

来源: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 Core 選項系統的主要實現在 Microsoft.Extensions.Options 和 Microsoft.Extensions.Options.ConfigurationExtensions 兩個 Nuget 包。對於一個框架的源碼進行解讀,我們可以從我們常用的框架中的類或方法入手 ...
  • 最近在工作中遇到一個問題,就是我有多個線程會調用bitmap對象,運行的時候報錯,對象當前正在其他地方使用。第一反應肯定是加鎖啊,於是我就在每個用到bitmap的地方都加了鎖,但是運行之後依然報這個錯 測試代碼如下 using System; using System.Drawing; using ...
  • 一:背景 1. 講故事 前段時間有位朋友微信找到我,說他的程式使用 hsl 庫之後,採集 plc 時記憶體溢出,讓我幫忙看一下怎麼回事,哈哈,貌似是分析之旅中的第二次和 hsl 打交道,既然找到我,那就上 windbg 說話吧。 二:WinDbg 分析 1. 為什麼會記憶體溢出 簡單觀察程式的提交記憶體之 ...
  • 在 IIS 上啟用 Websocket 在 Windows Server 2012 或更高版本上啟用對 WebSocket 協議的支持: 備註 使用 IIS Express 時無需執行這些步驟 通過“管理”菜單或“伺服器管理器”中的鏈接使用“添加角色和功能”嚮導。 選擇“基於角色或基於功能的安裝”。 ...
  • C#-垃圾回收機制(GC) 什麼是GC 官網中有這麼一句話: The garbage collector is a common language runtime component that controls the allocation and release of managed memory ...
  • 呆了2個大屏行業的公司,對大屏幕有一些瞭解,所以整理下所瞭解的觸摸屏相關概念。方便自己以及進入這個行業的小伙伴們,能有個系統、快速的認知。 觸摸屏詳細的知識點,網上其實都有。整理資料過程中,我也瞭解了更多的觸摸屏知識,像聲波屏、光學屏之類的之前就沒接觸。下麵分不同的模塊,給大家介紹 交互觸摸屏類型 ...
  • 近段時間忙於各種項目和對【易排平臺】的優化,沒顧得上分享APS相關的小技巧,回頭看看小公眾號的關註人數早已達1500+,在此爭取時間寫一下這段時間在項目上及平臺優化過程中遇到的一些小技巧,以感謝諸位的關註。過去數月的解決的問題中,涉及最多的是規劃模型中,實現各種時間維度的功能,目前在平臺上也稍有成果 ...
  • 針對大量log日誌快速定位錯誤地方 動態查看日誌 tail -f catalina.ou 從頭打開日誌文件 cat catalina.ou 可以使用 >nanjiangtest.txt 輸出某個新日誌去查看 [[email protected] logs]# cat -n catalina.out |grep 7 ...
  • 前言 RocketMQ是阿裡巴巴旗下一款開源的MQ框架,經歷過雙十一考驗、Java編程語言實現,有非常好完整生態系統。RocketMQ作為一款純java、分散式、隊列模型的開源消息中間件,支持事務消息、順序消息、批量消息、定時消息、消息回溯等 本篇文章第一部分屬於一些核心概念和工作流程的講解;第二部 ...
  • 在java,c#類的成員修飾符包括,公有、私有、程式集可用的、受保護的。 對於python來說,只有兩個成員修飾符:公有成員,私有成員 成員修飾符是來修飾誰呢?當然是修飾成員了。那麼python類的成員包括什麼呢? python成員: 欄位,方法,屬性 每個類成員的修飾符有兩種: 公有成員:內部外部 ...