李鴻赟
文章編號:2095-6835(2016)17-0022-01
摘 要:一個大型的應用信息化系統在部署實施過程中可能需要兼容和對接很多其他的信息化系統的功能和數據。在系統對接時,容易出現數據丟失、數據格式不兼容、狀態不容易同步、接口可靠性差等問題。針對以上幾個系統對接中存在的問題,研究了融合對接多個業務系統功能和數據框架必備的一些基本功能。
關鍵詞:融合多業務;信息化系統;數據格式;功能接口
中圖分類號:TN929.1 文獻標識碼:A DOI:10.15913/j.cnki.kjycx.2016.17.022
1 融合多業務的信息化系統概述
隨著社會的快速發展,尤其是近年來信息技術行業的迅猛發展,社會生產效率得到了有效的提高。但是,信息技術行業更新換代的速度非常快,一個信息化系統數年后可能滿足不了新的需求。
在一個涉及大型組織機構的單位中,如果要部署實施一套新的信息化系統,將會面臨很多原有系統數據整合的問題。在這些原有的信息化系統中,有一部分系統功能可能由于種種原因不會被新系統取代,舊系統的功能需要在新系統中繼續發揮。另外,有一部分原有信息化系統需要被新系統完全取代,但是這些舊信息系統中沉淀了許多不能丟棄的數據,并且這些業務數據需要在新系統中無縫切換,從而實現系統功能的平滑過渡。
2 融合多業務的信息化系統存在的問題
2.1 數據格式不兼容
每個舊系統擁有不同的數據庫,其中,表結構設計大部分無法直接被應用到現有系統中,并且一部分數據與新系統格式不匹配,另一部分數據可能不滿足新系統的需求,需要補充和擴展。
2.2 功能接口不匹配
在舊系統中,設計的功能接口在新系統中基本無法直接調用,有的接口格式和類型不匹配,有的功能接口的原有設計邏輯可能不符合當前新系統的使用邏輯,從而無法直接利用。
2.3 運行狀態不同步
在新系統的部分功能依賴于原有舊系統運行時,由于系統功能運行出錯、狀態返回錯誤、原系統對外接口不完善等多種問題,新系統在調用舊系統功能時,得到的功能運行狀態與實際系統運行狀態不一致。這就會導致新系統的功能無法正常發揮。
2.4 接口可靠性差
由于原系統提供的接口起初對外接口的設計原因,或者由于其他客觀原因,原系統的功能無法很好地在新系統中調用。當新系統在調用多個舊系統協作時,在多個系統接口不可靠的情況下,完整的系統功能將消耗大量的時間等待重復嘗試,從而大大降低系統的運行效率。
3 融合多業務的信息化系統框架設計
針對上述融合多業務的信息化系統存在的問題,從以下4個方面著手解決后,信息化系統的運行穩定性和運行效率都得到了有效的提升。
3.1 數據對接適配
在設計數據存儲時,需要設計好數據庫表結構,對于數據量比較大的數據,要提前做好數據庫的分庫和分表,以支持在與高并發系統對接時傳遞的數據量。
在面對大量異構系統對接時,除了要做好大量結構化的數據庫數據設計對原系統的兼容外,還有很大一部分數據,比如配置文件、運行過程的臨時數據等不適合存儲在RDBMS中,以及一部分數據量很大,但是實時性要求不是很高的數據,在采用結構化存儲時會引起讀寫性能問題。對于這些數據,可以采用非結構化存儲,采用NOSQL數據存儲技術,然后通過最終一致性提升系統的可用性。
3.2 功能接口適配
對于原有系統功能接口的調用模塊設計,采用設計模式中的適配器。其中,適配器主要分為具備以下2類功能的適配器:①最基本的將原系統功能的接口與現有系統適配,使得現有系統可以直接調用原系統的功能接口;②需要更進一步地對原系統接口的功能邏輯封裝,提供更加符合現有系統功能邏輯的接口。
3.3 狀態監測機制
原有系統的狀態監測主要包括數據同步監測和系統運行狀態監測。其中,數據同步監測可實時、同步地監測所有的結構化數據和非結構化數據,保證系統程序的運行基礎數據同步。在原有舊系統運行的過程中,新系統要對舊系統的運行狀態進行實時監測,以確保舊系統按照符合新系統調用邏輯運行,并且在運行狀態出現問題后可以及時地報警通知,從而保證新系統運行的可靠性。
3.4 消息通知機制
在新系統的某個功能的發揮依賴于多個舊系統時,可以將多個舊系統的功能拆分出來,區別出哪些功能是需要同步運行的,哪些功能是需要異步運行的。對于這2類接口,都采用不同的消息隊列同步調用,比如淘寶的開源框架Notify消息隊列引擎。對于需要同步調用的接口,必須同步調用每個接口,等待所有接口都執行完成后,接口調用才算完畢;對于可以異步調用的接口,可以并發地去調用這些接口,減少系統接口運行的總時間,并且對于調用失敗的接口調用,可以存儲在消息隊列中,等待失敗的接口調用成功執行完畢后,對后續失敗的接口重新調用。
4 結束語
綜上所述,在設計一個大型信息化系統時,如果該系統最后在應用中存在多個系統對接問題,那么必須提前制訂應對方案。本文的解決方式在應用中有效地實現了多個系統的對接,在多個系統的對接過程中,其效率得到了提升,可靠性得到了保障。
參考文獻
[1]謝華成,陳向東.面向云存儲的非結構化數據存儲[J].計算機應用,2012(07).
[2]司徒放.基于事件的分布式系統監控[D].上海:上海交通大學,2009.
[3]阿里中間件團隊.中間件及雙十一實踐·消息中間件篇[EB/OL].[2014-03-05].http://jm.taobao.org/2014/03/05/3483/.
〔編輯:劉曉芳〕