《電子技術應用》
您所在的位置:首頁 > 通信與網(wǎng)絡 > 設計應用 > RFID中間件基于集群技術的研究與開發(fā)
RFID中間件基于集群技術的研究與開發(fā)
張樂 王東
來源: RFID世界網(wǎng)
摘要: 隨著RFID(Radio Frequency Identification)技術的推廣,越來越多的企業(yè)開始使用RFID 技術, 并且正在被應用到很多著名的ERP 系統(tǒng)中去,例如EBS 和SAP 系統(tǒng)。在整合RFID 中間件和ERP 系統(tǒng)時,我們遇到了很多挑戰(zhàn)。對于大多數(shù)的ERP 系統(tǒng),高可靠性、高可用性、高擴展性、高性能是至關重要的,因此在RFID 中間件與ERP 系統(tǒng)整合過程中,RFID 中間件也必須像必須向上層應用系統(tǒng)提供高質(zhì)量的服務, 才能保證整個系統(tǒng)的高可靠性、高可用性、高擴展性、高性能。  為了解決這些問題, 我們將集群技術應用到中間件中來...
Abstract:
Key words :

    1 前言

 隨著RFID(Radio Frequency Identification)技術的推廣,越來越多的企業(yè)開始使用RFID 技術, 并且正在被應用到很多著名的ERP 系統(tǒng)中去,例如EBS 和SAP 系統(tǒng)。在整合RFID 中間件和ERP 系統(tǒng)時,我們遇到了很多挑戰(zhàn)。對于大多數(shù)的ERP 系統(tǒng),高可靠性、高可用性、高擴展性、高性能是至關重要的,因此在RFID 中間件與ERP 系統(tǒng)整合過程中,RFID 中間件也必須像必須向上層應用系統(tǒng)提供高質(zhì)量的服務, 才能保證整個系統(tǒng)的高可靠性、高可用性、高擴展性、高性能。

 為了解決這些問題, 我們將集群技術應用到中間件中來。RFID 中間件是基于組件的形式開發(fā)的,因此系統(tǒng)可以粗略的劃分為2 個部分:數(shù)據(jù)和組件。對于數(shù)據(jù),我們可以利用集群的分布式數(shù)據(jù)管理模塊來處理, 通過分布式緩存服務形成同一的數(shù)據(jù)視圖,使得每個節(jié)點都可以訪問到其他節(jié)點的數(shù)據(jù);通過復制緩存服務為每一個數(shù)據(jù)在不同節(jié)點產(chǎn)生一個備份, 使得數(shù)據(jù)具有高可靠性和高可用性。對于組件,我們通過組件調(diào)度策略是把所有的組件分配到不同的節(jié)點去, 以實現(xiàn)系統(tǒng)的高擴展性和高性能。

    2 系統(tǒng)架構

 2.1 整體架構

 設備管理層:RFID 中間件的底層系統(tǒng)部分,完成對RFID 系統(tǒng)中的所有硬件設備的管理與監(jiān)控。為不同生產(chǎn)廠家的讀寫設備提供了統(tǒng)一的接口,屏蔽了底層環(huán)境的異構性和復雜性;對各種硬件設備進行統(tǒng)一的管理, 極大地簡化和加快了應用系統(tǒng)和設備的集成。

 

    數(shù)據(jù)處理層: 數(shù)據(jù)處理層需要對原始數(shù)據(jù)進行處理,包括數(shù)據(jù)過濾以消除重復讀取產(chǎn)生的冗余數(shù)據(jù), 位過濾篩選感興趣的數(shù)據(jù),數(shù)據(jù)聚合分組等等。從而減少數(shù)據(jù)量并且保留感興趣的數(shù)據(jù)。

 應用程序級接口層:提供標準化的事件接口,應用系統(tǒng)可通過向其發(fā)送事件請求來訂閱需要的數(shù)據(jù)。事件請求中定義了數(shù)據(jù)處理的方式以及發(fā)送報告的格式。該層解析應用系統(tǒng)的事件請求,根據(jù)請求中的定義調(diào)用設備層獲取數(shù)據(jù)并對采集到的原始數(shù)據(jù)進行數(shù)據(jù)緩存、數(shù)據(jù)編碼解析、數(shù)據(jù)過濾和數(shù)據(jù)歸并等基本數(shù)據(jù)處理操作。最后將處理結果封裝成報告,發(fā)送給應用系統(tǒng)。

 信息服務層:提供各種RFID 信息服務,包括存儲捕獲的事件、對事件進行推理、提供信息的查詢等,協(xié)助應用程序完成相應的業(yè)務操作。

 業(yè)務集成層:用戶可以結合具體的業(yè)務,定義相應的業(yè)務模型, 由RFID 中間件根據(jù)定義的業(yè)務模型來輔助完成相應業(yè)務,最后將處理的結果與后臺應用系統(tǒng)進行整合。

 集群服務層: 為上層的應用系統(tǒng)提供一個統(tǒng)一的中間件視圖,管理集群節(jié)點狀態(tài),系統(tǒng)所有組件在各個節(jié)點間的分配,并且提供統(tǒng)一的分布式緩存視圖。

 2.2 集群服務層

 集群服務層主要由以下4 個部分組成:

 跟蹤服務:該模塊主要管理集群系統(tǒng)內(nèi)的節(jié)點成員列表和注冊服務列表。當節(jié)點啟動時,該服務自動啟動,并且將該節(jié)點加入到集群中,同時維護集群內(nèi)其他節(jié)點列表,探測節(jié)點失敗狀態(tài),并且維護集群中所注冊的服務列表(主要就是分布式緩存服務)。分布式緩存服務:該模塊允許節(jié)點去訪問其他節(jié)點的數(shù)據(jù),這樣就可以使得數(shù)據(jù)只保存在一個節(jié)點中, 另外通過悲觀鎖來實現(xiàn)分布式緩存的一致性。

 復制緩存服務: 該模塊同步的復制分布式緩存服務中的數(shù)據(jù),將復制數(shù)據(jù)保存在其他節(jié)點上。當數(shù)據(jù)發(fā)生變動時,復制數(shù)據(jù)自動相應變動。當集群節(jié)點增加時,自動將復制數(shù)據(jù)均攤到新增節(jié)點中,實現(xiàn)復制數(shù)據(jù)的負載平衡。當集群節(jié)點發(fā)生故障或者離開集群時,備份數(shù)據(jù)自動變?yōu)榭稍L問數(shù)據(jù),并且在其他節(jié)點備份該數(shù)據(jù)。

 組件管理:該RFID 中間件是面向組件開發(fā)設計的,每個層次都是由多個組件串行或者并行組合實現(xiàn)其功能。該模塊就是通過制定一定的策略,來決定組件如何分布在各個節(jié)點,并且協(xié)同工作,來提高系統(tǒng)性能

    3 系統(tǒng)實現(xiàn)

 3.1 組件定義

 組件是系統(tǒng)最基本的功能模塊, 每個層次的服務都是通過多個組件串行或者并行組合來實現(xiàn)其功能的。設備管理層的基本組件就是device 組件,每個device 組件對應一個實際讀寫器,所有的device 組件并行工作就組成了設備管理層。數(shù)據(jù)處理層的基本組件是各種過濾器,包括冗余過濾器、位過濾器等等,多個過濾器串行工作,使得要處理的數(shù)據(jù)依次通過這些過濾器,則實現(xiàn)了數(shù)據(jù)處理層的工作。

 3.2 組件結構

 每個組件都包含輸入和輸出, 在這里輸入和輸出都要掛在數(shù)據(jù)緩存總線上, 各個節(jié)點的數(shù)據(jù)緩存總線都有分布式緩存服務來管理,并且生成一致的數(shù)據(jù)視圖,這樣就把分布在各個節(jié)點的組件通過分布式緩存服務整合了起來。結構如下:

 3.3 組件類型

 在確定組件協(xié)同工作機制之前, 首先需要定義一下組件的類型:有狀態(tài)組件和無狀態(tài)組件。

 有狀態(tài)組件:輸出結果的產(chǎn)生不只依賴當前的輸入數(shù)據(jù),還依賴于之前的輸入數(shù)據(jù)。每一次輸入數(shù)據(jù)都會對后續(xù)結果的產(chǎn)生有影響。設備管理層的device 組件就是一個有狀態(tài)組件,因為device 組件中維護著與讀寫器之間的連接, 該連接是有狀態(tài)的,所以device 組件也是有狀態(tài)的。數(shù)據(jù)處理層的冗余過濾器也是有狀態(tài)的組件, 因為每次輸出結果時都要判斷指定時間內(nèi)是否存在相同的數(shù)據(jù)。應用程序級接口層的EventCycle 組件CommandCycle組件也是有狀態(tài)的組件, 因為產(chǎn)生的報告與指定時間段內(nèi)的所有數(shù)據(jù)有關。

 無狀態(tài)組件:輸出結果的產(chǎn)生只與當前的輸入數(shù)據(jù)有關。在輸入數(shù)據(jù)確定的情況下,輸出數(shù)據(jù)也是確定的。數(shù)據(jù)處理層中的位過濾器是無狀態(tài)組件, 因為它只需要根據(jù)當前數(shù)據(jù)數(shù)據(jù)的EPC 碼來判斷是否符合過濾條件,與之前狀態(tài)無關。應用程序級接口層的Dispatcher 組件, 負責將產(chǎn)生的報告分發(fā)至指定URI,也是一個無狀態(tài)組件。

 3.4 負載均衡

 根據(jù)組件分類, 有狀態(tài)組件和無狀態(tài)組件我們將采用不同的策略。

 對于無狀態(tài)組件,由于不涉及之前輸入數(shù)據(jù)的狀態(tài),數(shù)據(jù)即時產(chǎn)生即時處理。因此,我們在集群每一個節(jié)點處都創(chuàng)建出所有的無狀態(tài)組件, 每個節(jié)點的無狀態(tài)組件將通過一定負載均衡策略來獲得數(shù)據(jù)的處理權, 從而將數(shù)據(jù)計算處理的工作量分散到各個節(jié)點。

 可以采用的負載均衡策略目前有2 種:

 輪詢調(diào)度算法(Round-Robin Scheduling):針對每一個層次,把來自數(shù)據(jù)緩存總線的數(shù)據(jù)輪流分配給集群中各個節(jié)點, 從1開始,直到N(集群內(nèi)節(jié)點數(shù)),然后重新開始循環(huán)。由于無狀態(tài)組件不會占用高消耗的系統(tǒng)資源, 如數(shù)據(jù)庫連結、Socket 連接等(如果擁有連接,該組件應屬于有狀態(tài)組件),因此輪詢調(diào)度算法基本可以實現(xiàn)無狀態(tài)組件在各個節(jié)點上處理能力的負載均衡。

 就近調(diào)度算法:在各個層次中,無狀態(tài)組件一般要與有狀態(tài)組件相結合,共同完成該層次所提供的功能。就近調(diào)度算法就是根據(jù)有狀態(tài)組件所處節(jié)點位置,來決定無狀態(tài)組件所處位置,使該層次中所有無狀態(tài)組件與有狀態(tài)組件處于同一個節(jié)點。這種算法的優(yōu)點就是當一個層次中所有串行操作的組件都處于同一個節(jié)點時, 數(shù)據(jù)在每一個組件處理完成時不必在不同的節(jié)點間遷移, 大大減少了數(shù)據(jù)遷移時的時間延遲。該算法的缺點就是,負載均衡的效果很大程度上取決于有狀態(tài)組件的分布情況對于有狀態(tài)組件,參見后面的組件調(diào)度策略。

 3.5 組件調(diào)度策略

 該策略主要用來分配有狀態(tài)組件在各個節(jié)點的分布, 位于組件管理模塊中。

 1) 平均分配策略

 平均分配策略即將每個層次中的有狀態(tài)組件平均的分配到各個節(jié)點中。

 該策略的優(yōu)點是實現(xiàn)簡單, 在加入新節(jié)點或者節(jié)點故障時也比較容易在集群中重新分配組件。

 該策略的缺點是大量的數(shù)據(jù)遷移帶來不可忽視的延遲。不同層次間的數(shù)據(jù)可能需要遷移到不同的節(jié)點, 來移交給下一個層次的組件來處。相同層次內(nèi),也有能由多個組件組成一個串行操作,當這些組件位于不同節(jié)點時,也會帶來大量的層次內(nèi)組件間的數(shù)據(jù)遷移。

 2) 流水分配策略

                             

 如上圖所示,流水分配策略就是類似于流水線作業(yè),按層次分配組件,將相同層次的組件放在相同的節(jié)點中。

 該策略的優(yōu)點是實現(xiàn)也相對比較簡單。使得相同節(jié)點內(nèi)串行操作組件的數(shù)據(jù)全部位于本地節(jié)點內(nèi), 完全消除這類數(shù)據(jù)操作遠程存儲和數(shù)據(jù)遷移的時間延遲。

 該策略的缺點是不能做到負載均衡, 不同層次間的計算量差異較大,也就導致了不同節(jié)點間的負載不均衡。不同節(jié)點層次間的數(shù)據(jù)遷移量很大, 對于這一點可以利用分布式緩存服務的批量遷移功能,減少遷移次數(shù),增大每次的遷移數(shù)據(jù)量,來減少時間延遲。

 3) 并行分配策略
 

      

    如上圖所示,并行分配策略就是類似于并行作業(yè),將處理相同邏輯的讀寫器定義為一個邏輯讀寫器組, 從邏輯讀寫器組出發(fā),跟蹤數(shù)據(jù)流動的路徑,將數(shù)據(jù)流經(jīng)的所有的組件都分配在同一個節(jié)點處。

 該策略的優(yōu)點是使得數(shù)據(jù)的本地副本只在一個節(jié)點內(nèi)傳遞,盡可能的消除數(shù)據(jù)遠程調(diào)用和數(shù)據(jù)遷移的時間延遲,復制緩存服務也可以批量異步的完成備份數(shù)據(jù)的更新操作。

 該策略的缺點是程序?qū)崿F(xiàn)的復雜度高, 當邏輯不相關的組件之間的交叉引用增多時,該策略的效率將會明顯下降。這種情況下,應當考慮重新設計組件架構,適當增加重復組件,以減少不相關組件之間的交叉引用關系。

    4 小結

 本文第一次將集群技術引入到RFID 中間件中來。并且討論了分布式數(shù)據(jù)管理和組件調(diào)度策略。分布式數(shù)據(jù)管理通過分布式緩存服務形成同一的數(shù)據(jù)視圖, 使得每個節(jié)點都可以訪問到其他節(jié)點的數(shù)據(jù); 通過復制緩存服務為每一個數(shù)據(jù)在不同節(jié)點產(chǎn)生一個備份,使得數(shù)據(jù)具有高可靠性和高可用性。組件調(diào)度策略是把所有的組件分配到不同的節(jié)點去, 以實現(xiàn)系統(tǒng)的高擴展性和高性能。最終實現(xiàn)了RFID 中間件的高可靠性、高可用性、高擴展性、高性能。

 本文作者創(chuàng)新點: 本文第一次將集群技術引入到RFID 中間件中來, 并且討論了分布式數(shù)據(jù)管理和組件調(diào)度策略在中間件中的實現(xiàn),最終實現(xiàn)了RFID 中間件的高可靠性、高可用性、高擴展性、高性能。
 

此內(nèi)容為AET網(wǎng)站原創(chuàng),未經(jīng)授權禁止轉(zhuǎn)載。