App下載

大數(shù)據(jù)分析中流分析和工作流引擎的使用與特點(diǎn)!

臭臉大賽總冠軍 2021-08-25 10:49:44 瀏覽數(shù) (5311)
反饋

在現(xiàn)代 IT 架構(gòu)中,實(shí)時(shí)處理連續(xù)的業(yè)務(wù)數(shù)據(jù)和事件流變得越來越重要。這種類型的架構(gòu),其中事件正在構(gòu)建數(shù)據(jù)處理的中心,也稱為響應(yīng)式流架構(gòu)。在下文中,我將展示如何借助工作流技術(shù)解決一些相關(guān)挑戰(zhàn)。

讓我們先仔細(xì)看看這種類型的架構(gòu)。基本上,基于事件的數(shù)據(jù)處理并不新鮮,實(shí)際上已經(jīng)在各個(gè)專業(yè)領(lǐng)域(例如金融部門)中發(fā)展了數(shù)十年。但是,自過去幾年以來,出現(xiàn)了處理數(shù)據(jù)流的新標(biāo)準(zhǔn)。像  Apache KafkaStormFlink, or Spark 的日益普及,推動了新的炒作。 

從工業(yè)生產(chǎn)系統(tǒng)到多人電腦游戲,越來越頻繁地使用所謂的流式架構(gòu),以便能夠?qū)崟r(shí)處理大數(shù)據(jù)。流媒體架構(gòu)已經(jīng)發(fā)展成為現(xiàn)代科技公司的核心架構(gòu)元素。在許多公司中,實(shí)時(shí)流已成為其架構(gòu)中的核心系統(tǒng)。

目標(biāo)是能夠更快地集成新的系統(tǒng)解決方案并連接任何類型的數(shù)據(jù)流。流媒體架構(gòu)不僅存在于 eBay、Netflix 或亞馬遜等技術(shù)巨頭中,而且在今天,每一家致力于業(yè)務(wù)流程數(shù)字化的現(xiàn)代科技公司都可以使用流媒體架構(gòu)。那么,構(gòu)建這樣一個(gè)架構(gòu)的主要挑戰(zhàn)是什么?

處理數(shù)據(jù)流

在事件流的早期,數(shù)據(jù)流被記錄并隨后進(jìn)行分析(批處理),實(shí)際業(yè)務(wù)邏輯完全不受影響。但是,隨著業(yè)務(wù)邏輯變得更加復(fù)雜,處理數(shù)據(jù)變得更加困難。因此,處理數(shù)據(jù)流的一般任務(wù)提出了許多不同的挑戰(zhàn)。

來自不同來源(Producer)的數(shù)據(jù)需要進(jìn)行排序、分類并分派到不同的目標(biāo)(Consumer)。生產(chǎn)者可以生成不同類型的事件,而消費(fèi)者通常只對可能由不同消費(fèi)者創(chuàng)建的特定事件感興趣。系統(tǒng)必須能夠以協(xié)調(diào)的方式對數(shù)據(jù)進(jìn)行分區(qū)、結(jié)構(gòu)化和分發(fā)。

為了保證高數(shù)據(jù)吞吐量,此類系統(tǒng)必須水平擴(kuò)展。與此同時(shí),Apache Kafka已成為此類技術(shù)的事實(shí)上的標(biāo)準(zhǔn)。它提供了很大的靈活性,并且可以以多種不同的方式集成到其他系統(tǒng)中。

流分析和業(yè)務(wù)處理

但是,捕獲數(shù)據(jù)流只是挑戰(zhàn)的一部分。某些數(shù)據(jù)處理必須與傳入數(shù)據(jù)同時(shí)進(jìn)行,以便能夠迅速將結(jié)果用于決策。例如,購物車系統(tǒng)中的產(chǎn)品選擇可以觸發(fā)推薦系統(tǒng)并行執(zhí)行。這種類型的需求在流架構(gòu)中創(chuàng)建了另一個(gè)構(gòu)建塊——稱為流分析。

有時(shí),來自數(shù)據(jù)流的單個(gè)事件足以觸發(fā)預(yù)定義的業(yè)務(wù)邏輯。但是,通常需要能夠識別不同事件之間的聯(lián)系,以便運(yùn)行能夠產(chǎn)生實(shí)際業(yè)務(wù)價(jià)值的高級業(yè)務(wù)流程。通過在給定的時(shí)間段內(nèi)累積它們,可以在時(shí)移的相似事件之間建立這種聯(lián)系。例如,在線商店系統(tǒng)中對某種產(chǎn)品的短期需求增加可能會觸發(fā)額外生產(chǎn)線的啟動。在其他情況下,可能需要關(guān)聯(lián)某些不同類型的事件并合并數(shù)據(jù)以觸發(fā)相應(yīng)的業(yè)務(wù)流程。這些方法也稱為Windowing和 Joining。


在所有這些情況下,都會實(shí)施所謂的微批次來運(yùn)行流分析模塊內(nèi)的業(yè)務(wù)邏輯。Apache Kafka Streams是Kafka-Stack 中的一個(gè)擴(kuò)展,提供了許多這些功能。它允許使用不同的編程語言(如 Java 或 Scala)開發(fā)微批次。在JavaSpektrum 雜志2021/03版本之前,來自 Siemens AG 的 George Mamaladze 用更廣泛的方法描述了這個(gè)概念。

然而,微批處理帶來了新的挑戰(zhàn)。業(yè)務(wù)邏輯不能再用簡單的功能來描述了。例如,需要有狀態(tài)算法來保持一段時(shí)間內(nèi)的數(shù)據(jù)聚合。另一個(gè)要求是這些算法的并行執(zhí)行與相應(yīng)的狀態(tài)管理。因此,有必要保留這些狀態(tài),并在出現(xiàn)錯(cuò)誤時(shí)在上次中斷的點(diǎn)恢復(fù)業(yè)務(wù)流程。這種業(yè)務(wù)邏輯的實(shí)現(xiàn)很復(fù)雜,而且通常很耗時(shí)。

為了能夠管理更復(fù)雜的長期運(yùn)行的業(yè)務(wù)流程,工作流引擎成為實(shí)現(xiàn)數(shù)據(jù)流和業(yè)務(wù)邏輯分離的重要構(gòu)建塊。工作流引擎在處理復(fù)雜業(yè)務(wù)邏輯和長期保持業(yè)務(wù)狀態(tài)方面進(jìn)行了優(yōu)化。主要區(qū)別在于所有正在運(yùn)行的微批次的狀態(tài)管理。工作流引擎的模型驅(qū)動架構(gòu)允許快速適應(yīng)不斷變化的需求和技術(shù)。

基于新的傳入事件(由 Micro-Batch 創(chuàng)建),工作流引擎可以啟動新的業(yè)務(wù)流程或繼續(xù)已啟動的流程實(shí)例。工作流引擎將自動持久化業(yè)務(wù)流程的狀態(tài),并可以從不同的生產(chǎn)者收集事件。然而,單個(gè)處理步驟的結(jié)果或業(yè)務(wù)流程的完成也可能產(chǎn)生新事件。  

所以,一個(gè)內(nèi)無流架構(gòu),將工作流引擎需要的角色消費(fèi)者和生產(chǎn)者控制業(yè)務(wù)流程的整個(gè)生命周期。


使用 Imixs-Workflow 進(jìn)行流分析

Imixs-Workflow是一個(gè)開源工作流引擎,提供廣泛的功能來控制復(fù)雜的業(yè)務(wù)流程?;谑录墓ぷ髁饕婵梢宰鳛槲⒎?wù)運(yùn)行,并且可以通過其微內(nèi)核架構(gòu)進(jìn)行擴(kuò)展。Imixs-Workflow 已經(jīng)帶有一個(gè) Apache Kafka 適配器,它可以很容易地從響應(yīng)式流媒體平臺開始處理事件。 

所述 Imixs-Kafka Adapter 充當(dāng)卡夫卡堆棧內(nèi)產(chǎn)生的事件的一個(gè)消費(fèi)者。憑借其 Autowire 功能,Imixs-Workflow 還可以在處理生命周期中自動發(fā)送工作流消息。這允許在分布式微服務(wù)架構(gòu)中構(gòu)建更復(fù)雜的業(yè)務(wù)流程。 

模型驅(qū)動的業(yè)務(wù)邏輯

業(yè)務(wù)流程建模符號 (BPMN)——當(dāng)今業(yè)務(wù)流程建模的標(biāo)準(zhǔn)——可以幫助以模型驅(qū)動的方式構(gòu)建靈活的架構(gòu)。BPMN 2.0 是一種基于 XML 的可擴(kuò)展建模標(biāo)準(zhǔn),允許對復(fù)雜的業(yè)務(wù)流程進(jìn)行建模、分析和執(zhí)行。 

在像 Imixs-Workflow 這樣的基于事件的工作流引擎中,業(yè)務(wù)流程的不同狀態(tài)被描述為Tasks。從一種狀態(tài)到下一種狀態(tài)的轉(zhuǎn)換由事件元素描述。事件可以通過使用 Kafka 流事件觸發(fā),也可以由外部服務(wù)或人類參與者觸發(fā)。通過將任務(wù)和事件與網(wǎng)關(guān)元素相結(jié)合,可以對業(yè)務(wù)規(guī)則進(jìn)行建模,以根據(jù)收集到的數(shù)據(jù)做出決策并對不同情況做出反應(yīng)。  


聚合流事件

使用工作流引擎使用事件流的優(yōu)點(diǎn)是能夠在特定上下文中長時(shí)間聚合數(shù)據(jù)。數(shù)據(jù)可以從不同來源聚合和轉(zhuǎn)換,并與現(xiàn)有業(yè)務(wù)數(shù)據(jù)相結(jié)合。 

例如,在購物系統(tǒng)中,新客戶的注冊可以觸發(fā) VIP 會員流程。工作流引擎首先僅對新客戶注冊做出反應(yīng),以啟動 VIP 會員業(yè)務(wù)流程。從這一刻起,工作流引擎會對購物系統(tǒng)中啟用 VIP 會員資格的某些事件做出反應(yīng)。例如,這可以是購買某些產(chǎn)品或訂閱。


更改業(yè)務(wù)邏輯不需要對代碼庫進(jìn)行任何更改或?qū)崿F(xiàn)新的微批次。此外,可以在運(yùn)行時(shí)調(diào)整新的附加業(yè)務(wù)工作流,而無需更改架構(gòu)。 

人工智能

基于 Imixs 微內(nèi)核架構(gòu),可以使用提供附加功能的各種適配器或插件模塊來擴(kuò)展業(yè)務(wù)流程。例如,Imixs-ML 適配器提供了一個(gè)通用 API 來集成各種 ML 框架,如 spaCy 或 Apache mxnet。借助這種適配器技術(shù),可以通過人工智能豐富業(yè)務(wù)處理。 

Imixs-ML 的核心概念基于自然語言處理 (NLP),它是機(jī)器學(xué)習(xí)的一個(gè)子領(lǐng)域。使用命名實(shí)體識別 (NER),可以分析給定的文本流,并且可以從任何類型的流事件中提取文本實(shí)體,例如人員、地點(diǎn),甚至發(fā)票數(shù)據(jù)(例如日期和發(fā)票總額)。這種機(jī)器學(xué)習(xí)過程的結(jié)果可用于對更復(fù)雜的業(yè)務(wù)邏輯進(jìn)行建模,并基于各種訓(xùn)練模型進(jìn)行業(yè)務(wù)討論。


持續(xù)學(xué)習(xí)

持續(xù)學(xué)習(xí)是 ML 訓(xùn)練模型從數(shù)據(jù)流中持續(xù)學(xué)習(xí)的能力。在實(shí)踐中,這意味著支持模型在新數(shù)據(jù)進(jìn)入時(shí)自主學(xué)習(xí)和適應(yīng)生產(chǎn)的能力。通過 Imixs-ML 適配器,這個(gè)概念被集成到業(yè)務(wù)流程的實(shí)時(shí)周期中。Imixs-Workflow 引擎可以根據(jù)業(yè)務(wù)流程的結(jié)果自動優(yōu)化 ML 訓(xùn)練模型。通過這種方式,來自事件流平臺的數(shù)據(jù)可用于生成新的訓(xùn)練模型以供未來處理。但人工操作員做出的決定也可用于改進(jìn)現(xiàn)有的 ML 訓(xùn)練模型。 

結(jié)論

通過將反應(yīng)式流架構(gòu)與現(xiàn)代業(yè)務(wù)流程管理的概念相結(jié)合,可以在很短的時(shí)間內(nèi)實(shí)現(xiàn)高度復(fù)雜的業(yè)務(wù)流程。得益于基于現(xiàn)代 BPMN 2.0 的工作流技術(shù)的模型驅(qū)動方法,即使是復(fù)雜的業(yè)務(wù)流程也可以在不改變整體架構(gòu)的情況下設(shè)計(jì)和執(zhí)行。這種類型的架構(gòu)為處理連續(xù)數(shù)據(jù)流開辟了全新的可能性。


0 人點(diǎn)贊