国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

什么是流程引擎?介紹流程引擎的架構設計方法

OSC開源社區 ? 來源:OSCHINA 社區 ? 作者:京東云開發者-馬瑞 ? 2022-10-20 09:59 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

1 什么是流程引擎

流程引擎是一個底層支撐平臺,是為提供流程處理而開發設計的。流程引擎和流程應用,以及應用程序的關系如下圖所示。

f0bd2a48-4fc3-11ed-a3b6-dac502259ad0.png

常見的支撐場景有:Workflow、BPM、流程編排等。本次分享,主要從 BPM 流程引擎切入,介紹流程引擎的架構設計方法。

1.1 什么是流程

簡單來說,流程就是一系列活動的組合。比如,用于企業辦公的 OA 系統中,就存在大量的申請審批類的流程。在生產制造業,有大量的從銷售端的訂單,到生產制造,再到簽收回款的生產銷售流程。在機器學習領域,有亞馬遜 AWS Sagemaker 的大數據處理、機器學習的應用。綜上,流程是一個概念,在和具體實現結合時,就產生了不同的流程產品,如 DevOps、Spring Data Stream 等。

在流程實現方面,主要可以分為 2 種實現方式,一種是用代碼實現,比如:用代碼實現一個加班申請,那么就要自己對接 SSO 進行單點登錄,通過接口拿到發起人和審批人的信息,同時保存表單數據。另一種方式是使用流程引擎來實現,流程引擎對接應用場景所需數據,如加班申請,流程引擎對接 SSO、OU、審批人配置、權限等,實現這樣一個流程,只需要關心流程配置、流程節點和流程表單即可,流程流轉以及流程的數據處理,都通過流程引擎來完成。
流程引擎可以快速落地流程實現,這也是流程引擎存在的價值。

1.2 什么是引擎

一般而言,引擎是一個程序或一套系統的支持部分。常見的程序引擎有游戲引擎、搜索引擎、殺毒引擎等。引擎是脫離具體業務場景的某一類業務場景的高度抽象和封裝。

比如,某 OA 公司,封裝了一套審批用的 workflow,實施人員只需要配置流程和表單即可交付項目。再比如,美國某公司做了一個 AI 引擎做 NBA(Next Best Action)推薦,封裝了推薦領域的常用算法,在不同的場景自動選擇和組合多種算法,進行智能推薦。

1.3 流程設計器

流程設計器是流程和引擎的連接方,用戶通過流程設計器,將某種 layout 和 rule 固化成某種流程,然后通過數據和數據上下文,使用流程引擎自動按照某種固化的流程進行執行。

我將目前見到的流程設計器的理論基礎,分為以下三類:1,自定義系;2,UML 中的活動圖系;3,BPMN 系。

1.3.1 自定義系

用于 Sagemaker 等場景的 AWS Step Function(自定義流程節點)

f0d69410-4fc3-11ed-a3b6-dac502259ad0.png

1.3.2 UML Activity Diagram

Flowportal BPM 的流程設計器

f10183a0-4fc3-11ed-a3b6-dac502259ad0.png

1.3.3 BPMN 系

activiti 的流程設計器

f1364d4c-4fc3-11ed-a3b6-dac502259ad0.png

炎黃盈動的流程設計器

f1dad57e-4fc3-11ed-a3b6-dac502259ad0.png

題外話:炎黃盈動的流程設計器,和 processon 中的流程設計器界面幾乎一樣,因為本質上是一家的。

2 流程引擎的應用

2.1 Workflow

工作流管理聯盟 (Workflow Management Coalition,WfMC) 作為工作流管理的標準化組織而成立。

WfMC 對工作流給出定義為:工作流是指一類能夠完全自動執行的經營過程,根據一系列過程規則,將文檔、信息或任務在不同的執行者之間進行傳遞與執行。

f2019858-4fc3-11ed-a3b6-dac502259ad0.png

在 workflow 中,流程引擎主要用于支撐流程審批和數據流轉,應用場景非常廣泛。

國外產品(開源或商用)通常需求和操作比較簡單,不會有國內的需求那么復雜。國內的產品,經歷了眾多客戶的錘煉,功能目前都比較強大。

一般而言,workflow 使用場景最多的是 OA 產品。在 OA 辦公中,包含了企業辦公中的大量元素,這些元素足夠形成特定的產品,比如門戶系統、移動辦公。在 OA 的項目落地過程中,結合行業、業務側重點又可以形成行業解決方案和專題方案。

以下是某 OA 公司產品和解決方案。

f217367c-4fc3-11ed-a3b6-dac502259ad0.png

2.2 BPM(Business Process Management)

Workflow 主要是解決審批和數據流轉,而 BPM 主要是解決端到端、信息孤島等問題而存在的。大多數用 BPM 產品的客戶,都是在 BPM 基礎上進行系統搭建,比如在 BPM 上面搭建 OA、CRM、HR 等系統。

BPM 的使用場景,比 Workflow 更廣泛,BPM 產品中包含大量的和第三方系統交互的組件和自定義 SQL、代碼組件。比如,BPM 系統中的文件觸發器,可以在海關等交互場景下,通過監控 FTP 服務器中的文件,自動觸發流程實例;可以通過定時器 Timer,自動每日執行數據同步,并通過 Mail 節點將同步結果通知到相關運營成員等。

f22bd816-4fc3-11ed-a3b6-dac502259ad0.png

f274cfc6-4fc3-11ed-a3b6-dac502259ad0.png

BPM 的應用,可以按照執行前、執行中和執行后來劃分。

f2f5aa7e-4fc3-11ed-a3b6-dac502259ad0.png

2.3 流程編排

流程編排是脫離流程業務領域的更高一層抽象,使用方可以通過流程編排系統,結合自己的業務場景進行業務定制。比如,可以將相關業務代碼,封裝成 function,然后通過云廠商平臺的 FAAS 平臺,將不同業務的 function 進行關聯和調度,從而完成某項任務。

3 流程引擎的架構設計

鑒于一些朋友可能沒有使用和接觸過流程引擎,先介紹流程引擎的組成單元,再介紹基于某個 BPM 產品的項目是如何進行開發的。我們通過 BPM 項目開發,對流程引擎的作用有個初步的認識。

3.1 BPM 流程引擎的組成單元

組織、角色、用戶、成員的組織架構托管;

流程資源文件的配置、校驗、存儲和執行,對不同的流程節點,流程引擎自動結合配置、數據處理其對應的業務邏輯,流程數據自動處理;

表單配置、數據綁定,表單數據的根據流程配置自動處理;

通用的數據接口;

3.1.1 組織架構的設計

f31d103c-4fc3-11ed-a3b6-dac502259ad0.png

3.1.2 流程設計器

流程設計器包含左側的分組節點列表,和右側的畫布。左側的節點可以如下進行設計。

f333e67c-4fc3-11ed-a3b6-dac502259ad0.png

問題:對于一個 XML 或 JSON 格式的流程圖,如何進行解析?

不同的節點,按照不同的業務場景,配置不同的配置項。比如,對于 Human Node 需要配置審批人,配置審批環節的展示表單,審批環節能夠修改哪些字段,哪些字段的修改要進行留痕等。

3.1.3 表單設計器

f34e6966-4fc3-11ed-a3b6-dac502259ad0.png

f480f5b0-4fc3-11ed-a3b6-dac502259ad0.png

這種是按照表單相關數據表,生成出一個表單,然后對表單字段進行配置和數據綁定。

f4b725ae-4fc3-11ed-a3b6-dac502259ad0.png

f4ee9ba6-4fc3-11ed-a3b6-dac502259ad0.png

這種是 Drag&Drop 控件,然后配置控件的屬性,如綁定字段等。

f51d7d04-4fc3-11ed-a3b6-dac502259ad0.png

這種是 Drag&Drop 控件,無需關聯數據庫表字段的表單

f53f939e-4fc3-11ed-a3b6-dac502259ad0.png

數據表生成表單的概要流程如下圖所示。

f575269e-4fc3-11ed-a3b6-dac502259ad0.png

拖拽控件綁定數據表字段的概要流程如下。

f5e3ea34-4fc3-11ed-a3b6-dac502259ad0.png

拖拽控件無需綁定數據表字段的概要流程。使用 NoSQL 的 Document 記錄或使用 RDS 提供的 JSON 類型進行保存會比較方便。

f64138b0-4fc3-11ed-a3b6-dac502259ad0.png

3.1.4 接口設計

結合 Activity 的接口設計,如下圖所示

f6532476-4fc3-11ed-a3b6-dac502259ad0.png

一些系統在創建一個流程任務的時候,要先按照流程模板先創建一個應用示例,再關聯發起人和備注,調用 RuntimeService,執行到 StartNode,這類設計因人而異,這么做略顯繁瑣。

3.2 基于流程引擎的項目開發實踐

3.2.1 流程項目實踐流程

確定組織架構

確定流程,包括流程布局、審批人設置、權限

確定表單信息(字段、類型、數據源、校驗規則)和表單樣式

確定頁面布局、樣式、數據字段、搜索、導入、導出

報表

3.2.2 組織架構

組織架構實現,有兩種方法,一種是按照維度進行數據管理,另一種是在同一棵組織架構樹下進行管理。

按照集團、公司、部門、用戶等不同維度,進行數據管理,比較常見,這里不做討論。下圖為按維度維護數據的示例。

f67575b2-4fc3-11ed-a3b6-dac502259ad0.png

按照同一棵組織架構樹進行數據維護,界面一般顯示為左樹右表。大多數商業化產品,都會將此組織架構樹進行內存緩存,以方便審批人查找、開窗選擇 OrgUnit、Role、User、Member 等場景。Member 的引入是為了解決一人多職等場景。一般發起流程的時候,需要帶出發起人擁有的 Member 列表,從而后續節點取合適的審批人。

f6aa5a5c-4fc3-11ed-a3b6-dac502259ad0.png

對于組織架構而言,需要考慮,系統本身要具備 OU 存儲的能力,對于沒有組織架構的用戶,可以直接在系統的組織架構中新建組織架構。同時,對于已有系統的客戶,可以通過組織架構數據同步來進行數據自動維護。對于用 AD 域內部管控的客戶來說,需要具備 AD 域身份認證的能力。對于復雜場景,比如用戶是 SaaS 化等復雜場景,組織架構也需要在系統內部,支持使用 API 的方式來獲取組織信息。

所以在組織架構設計的時候,要使用插件的方式來做,具體使用哪種插件,可以在配置文件中進行配置。以下為一個商業產品的組織架構操作界面示例。

f6cdae94-4fc3-11ed-a3b6-dac502259ad0.png

常見的組織架構操作還有組織架構同步,比如流程系統同步微信企業號、釘釘等,這里不再展開。

3.2.3 流程設計

我們想象的流程,可能是向下面的這種簡單流程。

f6dc2ee2-4fc3-11ed-a3b6-dac502259ad0.png

而實際項目,碰到的流程,一般是如下圖所示的情景。

f6f8c016-4fc3-11ed-a3b6-dac502259ad0.png

初步看幾個流程的模型文件是什么樣的,先有個印象。

f7170ddc-4fc3-11ed-a3b6-dac502259ad0.png
















${employeeName} would like to take ${numberOfDays} day(s) of vacation (Motivation: ${vacationMotivation}).










management






${vacationApproved == 'true'}





${vacationApproved == 'false'}



Your manager has disapproved your vacation request for ${numberOfDays} days.
Reason: ${managerMotivation}












${employeeName}






${resendRequest == 'true'}


${resendRequest == 'false'}



一個屏幕截圖都截不完的流程,如果用代碼去實現整個流程,其工作量和效率,可想而知。而實際做項目,使用基于流程引擎的產品來做項目的時候,只需要確定節點、節點配置、數據配置和權限即可。

問題:一般流程,都帶有郵件通知的節點,如何實現郵件通知節點?請考慮以下情景。

流程流轉和執行的時候,會遇到各種情況的錯誤,比如找不到審批人等,此時流程引擎要對數據做 rollback,而郵件通知節點的業務邏輯已經執行過了。

權限方面,對于流程資源,哪些部門可以申請,哪些角色不可申請,都應該做流程控制。而在流程執行過程中,流程數據、不是路程的相關人也都不應該看到流程,處理過流程的審批人,不可以再對流程進行處理等,都是權限方面要考慮的問題。

3.2.4 表單設計

如下圖所示的表單,可以分析以下,一個流程表單有多個主表信息和多個子表信息。一般而言,如果是通過流程引擎做非流程的數據處理,子表通過主表 ID 來做關聯,如果通過流程引擎做流程的數據處理,子表和主表通過 TaskId 來做關聯。以下為示例。

f736a192-4fc3-11ed-a3b6-dac502259ad0.png

流程系統需要表單設計器,一個流程的不同節點可以掛接不同的表單,以方便不同角色的人關注不同維度的流程信息

3.2.5 頁面設計

一般而言,對于流程的發起、審批、歷史記錄等,都是通用的系統界面。而一些業務場景,需要單獨做列表界面,以方便使用。對于已有門戶系統的客戶,需要融合其界面樣式。以下為曾經做過的項目示例。

f79892f8-4fc3-11ed-a3b6-dac502259ad0.png

f7f89022-4fc3-11ed-a3b6-dac502259ad0.png

3.2.6 報表

由于不是所有客戶都有報表系統,所以流程系統需要具備一個基本的報表功能。下圖為示例。

f877db34-4fc3-11ed-a3b6-dac502259ad0.png

有報表系統的客戶,可以使用其商業版報表系統,獲取(直接取、數倉)數據進行展示。常見的報表系統有 FineReport、Tableau、PowerBI 等。

3.3 BPM 流程引擎架構設計

3.3.1 流程引擎的架構設計

f8866ec4-4fc3-11ed-a3b6-dac502259ad0.png

3.3.2 發起流程

f89f87c4-4fc3-11ed-a3b6-dac502259ad0.png

流程引擎處理過程

f922a820-4fc3-11ed-a3b6-dac502259ad0.png

執行節點處理過程

f93c1c6a-4fc3-11ed-a3b6-dac502259ad0.png

問題:在流程引擎處理過程中,如果一個節點有多條連線,如何尋找 FromNodeId 是某個 Node 的連線?

人工處理時,指定連線 text

3.4 流程引擎架構設計

f9724790-4fc3-11ed-a3b6-dac502259ad0.png

3.4.1 業務識別

識別業務場景中的配置項,使用集合或分組的方式,讓業務可配置

支撐業務流程過程的可配置化

支撐業務場景中的數據,自動處理

3.4.2 流程引擎的實現

資源相關服務,資源加載,資源保存,資源加密等

配置項相關服務

PVM 虛擬機的實現,即通過某個節點(發起時為開始節點)作為初始節點,按照某個連線的 action 進行節點的自動執行的虛擬機

數據配置、數據權限

流程數據和業務數據的自動處理

4 商業機會

Business Process Analysis (BPA) 流程分析,幫助企業進行流程調整和優化

Process Assets Library(PAL)流程資產庫,對企業流程進行知識化沉淀,將制度和流程落地做綁定,讓審批人知曉流程中對應的職責

Process Simulate 流程模擬,自動化測試

Process Forecast 流程預測

低代碼平臺

更廣泛的機會,在于業務領域 + 流程引擎,比如:DevOps、RPA、應用與服務編排、數據編排、FaaS 編排等。





審核編輯:劉清

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • CRM
    CRM
    +關注

    關注

    1

    文章

    152

    瀏覽量

    22137
  • BPM
    BPM
    +關注

    關注

    0

    文章

    24

    瀏覽量

    8385
  • SSO
    SSO
    +關注

    關注

    0

    文章

    9

    瀏覽量

    7718

原文標題:流程引擎的架構設計

文章出處:【微信號:OSC開源社區,微信公眾號:OSC開源社區】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    基于圖撲 HT 引擎:數字孿生民航飛聯網方案

    與動態效果呈現,能夠搭建標準化、可交互的可視化管控界面,為工業互聯網監控運維場景提供一體化前端可視化實現方案。 核心技術架構設引擎底層支撐 HT for Web 引擎基于 WebGL 實現高性能 3D 圖形渲染,同時兼容 C
    的頭像 發表于 02-05 14:26 ?109次閱讀
    基于圖撲 HT <b class='flag-5'>引擎</b>:數字孿生民航飛聯網方案

    引擎是什么?

    引擎是光通信系統中的核心部件,它是一個集成化的光學子系統,負責實現光信號的收發處理,其性能對系統的信號傳輸有直接影響
    的頭像 發表于 01-22 17:43 ?1405次閱讀
    光<b class='flag-5'>引擎</b>是什么?

    充電樁SECC 方案:驅動電動汽車成為電網智慧儲能單元的核心引擎

    方式介紹 SECC 的核心組成結構,并呈現米爾 SECC 在系統架構中的價值。 一、SECC 的核心定位 在直流充電過程中,SECC 負責: 建立車輛與充電樁之間的通信 識別插槍與準備狀態 協商充電
    發表于 01-16 17:56

    外延片氧化清洗流程介紹

    外延片氧化清洗流程是半導體制造中的關鍵環節,旨在去除表面污染物并為后續工藝(如氧化層生長)提供潔凈基底。以下是基于行業實踐和技術資料的流程解析:一、預處理階段初步清洗目的:去除外延片表面的大顆粒塵埃
    的頭像 發表于 12-08 11:24 ?401次閱讀
    外延片氧化清洗<b class='flag-5'>流程</b><b class='flag-5'>介紹</b>

    硬件加密引擎在保障數據安全方面有哪些優勢呢?

    )通過硬件防火墻隔離,運算過程中密鑰和敏感數據僅在加密引擎內部流轉,不暴露至外部總線或內存。同時,硬件邏輯一旦固化,無法通過軟件篡改,避免惡意程序注入篡改加密流程。 物理防篡改能力:部分高端型號集成物理
    發表于 11-17 06:47

    開關電源測試流程方法合集

    的標準解決方案,因此本文針對開關電源電性能的測試流程方法進行總結。 本文主要介紹開關電源的基礎測試項目流程方法,其中溫度、濕度以及電磁類
    的頭像 發表于 10-31 09:36 ?1306次閱讀
    開關電源測試<b class='flag-5'>流程</b><b class='flag-5'>方法</b>合集

    開關電源有哪些測試流程方法?

    開關電源作為電子行業中應用最為廣泛的電源模塊,其測試流程方法需遵循 “從基礎功能到復雜性能、從靜態特性到動態可靠性” 的邏輯流程。具體的測試工程通常分為設計驗證測試、生產測試和驗證測試幾個階段
    的頭像 發表于 10-28 17:47 ?937次閱讀
    開關電源有哪些測試<b class='flag-5'>流程</b>和<b class='flag-5'>方法</b>?

    TensorRT-LLM的大規模專家并行架構設

    之前文章已介紹引入大規模 EP 的初衷,本篇將繼續深入介紹 TensorRT-LLM 的大規模專家并行架構設計與創新實現。
    的頭像 發表于 09-23 14:42 ?1114次閱讀
    TensorRT-LLM的大規模專家并行<b class='flag-5'>架構設</b>計

    CoWoP封裝的概念、流程與優勢

    本文介紹了CoWoP(Chip?on?Wafer?on?Substrate)封裝的概念、流程與優勢。
    的頭像 發表于 08-12 10:49 ?2911次閱讀
    CoWoP封裝的概念、<b class='flag-5'>流程</b>與優勢

    基于 HT 引擎鋁型材擠壓車間數字孿生技術實現

    。該系統無需依賴任何第三方插件,通過輕量化架構、高逼真渲染及多維度數據融合能力,實現了鋁型材擠壓產線的全流程可視化管理,為智慧工業產線建設提供了技術范本。
    的頭像 發表于 08-06 16:41 ?776次閱讀
    基于 HT <b class='flag-5'>引擎</b>鋁型材擠壓車間數字孿生技術實現

    信而泰×DeepSeek:AI推理引擎驅動網絡智能診斷邁向 “自愈”時代

    DeepSeek-R1:強大的AI推理引擎底座DeepSeek是由杭州深度求索人工智能基礎技術研究有限公司開發的新一代AI大模型。其核心優勢在于強大的推理引擎能力,融合了自然語言處理(NLP)、深度
    發表于 07-16 15:29

    技術分享 | 如何在2k0300(LoongArch架構)處理器上跑通qt開發流程

    技術分享 | 如何在2k0300開發板(LoongArch架構)處理器上跑通qt開發流程
    的頭像 發表于 05-20 11:05 ?900次閱讀
    技術分享 | 如何在2k0300(LoongArch<b class='flag-5'>架構</b>)處理器上跑通qt開發<b class='flag-5'>流程</b>

    工業物聯網:驅動工業變革的新引擎

    工業物聯網:驅動工業變革的新引擎
    的頭像 發表于 03-19 09:57 ?900次閱讀

    ?Diffusion生成式動作引擎技術解析

    Diffusion生成式動作引擎 Diffusion生成式動作引擎是一種基于擴散模型(Diffusion Models)的生成式人工智能技術,專注于生成連續、逼真的人類動作或動畫序列。這類引擎在游戲
    的頭像 發表于 03-17 15:14 ?3059次閱讀

    封裝失效分析的流程方法及設備

    本文首先介紹了器件失效的定義、分類和失效機理的統計,然后詳細介紹了封裝失效分析的流程、方法及設備。
    的頭像 發表于 03-13 14:45 ?2186次閱讀
    封裝失效分析的<b class='flag-5'>流程</b>、<b class='flag-5'>方法</b>及設備