999精品在线视频,手机成人午夜在线视频,久久不卡国产精品无码,中日无码在线观看,成人av手机在线观看,日韩精品亚洲一区中文字幕,亚洲av无码人妻,四虎国产在线观看 ?

基于CORBA的局域網(wǎng)監(jiān)控系統(tǒng)設(shè)計與實現(xiàn)

2014-10-21 20:04:55陳嬙嬙
電子世界 2014年6期

基于CORBA的局域網(wǎng)監(jiān)控系統(tǒng)設(shè)計與實現(xiàn)

華北電力大學 ?陳嬙嬙

【摘要】隨著工業(yè)的不斷發(fā)展,越來越多的自動化設(shè)備應(yīng)用在控制局域網(wǎng)中,如何監(jiān)控這些工業(yè)設(shè)備是個需要研究的課題。本文結(jié)合CORBA原理及實現(xiàn)過程,設(shè)計了基于CORBA的局域網(wǎng)監(jiān)控系統(tǒng)的體系架構(gòu),并對系統(tǒng)實現(xiàn)中的關(guān)鍵技術(shù)做了詳細闡述。

【關(guān)鍵詞】監(jiān)控系統(tǒng);CORBA;系統(tǒng)設(shè)計

1.引言

隨著計算機技術(shù)的快速發(fā)展,基于計算機網(wǎng)絡(luò)的分布式控制已成為日益重要的監(jiān)控途徑。遠程監(jiān)控系統(tǒng)可以采集現(xiàn)場設(shè)備運行時產(chǎn)生的動態(tài)數(shù)據(jù)和其它內(nèi)部數(shù)據(jù),通過這些數(shù)據(jù)調(diào)度中心可以有效的監(jiān)控現(xiàn)場設(shè)備運行狀況。然而,目前的監(jiān)控系統(tǒng)結(jié)構(gòu)復雜,存在著同一網(wǎng)絡(luò)環(huán)境下的不同操作平臺、不同通信協(xié)議以及不同的編程語言等問題。同時如何實現(xiàn)系統(tǒng)的可重用性、可移植性等問題都是傳統(tǒng)方法所難以解決的。

CORBA(Common Object Request Broker Architecture簡稱)是當今國際產(chǎn)業(yè)界最令人關(guān)注的中間件技術(shù)規(guī)范,它的主要目標就是在分布式異構(gòu)環(huán)境下實現(xiàn)信息和資源的共享[1]。技術(shù)屏蔽了不同操作系統(tǒng)、編程語言以及通信協(xié)議之間的差異。采用面向?qū)ο蟮姆椒ㄒ蕴峁┓植际綉?yīng)用軟件的可重用性和可移植性,實現(xiàn)了異構(gòu)環(huán)境下的客戶端和服務(wù)器端的通信,這樣既大大簡化了分布式應(yīng)用系統(tǒng)的開發(fā)和維護,又便于異構(gòu)環(huán)境下的系統(tǒng)集成,從而可以滿足未來遠程監(jiān)控系統(tǒng)擴展的需要。

本文結(jié)合已有的監(jiān)控系統(tǒng)產(chǎn)品,將CORBA技術(shù)應(yīng)用于局域網(wǎng)監(jiān)控系統(tǒng)設(shè)計中,同時結(jié)合實際工程的需要,提出基于CORBA的監(jiān)控系統(tǒng)的設(shè)計方案。該系統(tǒng)解決了分布式系統(tǒng)中的對象引用的管理問題,能夠準確的定位到監(jiān)控系統(tǒng)中的各個對象機制。

2.監(jiān)控系統(tǒng)的設(shè)計

2.1 監(jiān)控系統(tǒng)拓撲結(jié)構(gòu)設(shè)計

監(jiān)控系統(tǒng)主要由前端數(shù)據(jù)采集系統(tǒng)、工程師站和數(shù)據(jù)服務(wù)系統(tǒng)組成。通過安放在現(xiàn)場的IO系統(tǒng),數(shù)據(jù)采集系統(tǒng)采集現(xiàn)場各種設(shè)備的數(shù)據(jù);數(shù)據(jù)服務(wù)系統(tǒng)將采集數(shù)據(jù)匯總、存儲,并對數(shù)據(jù)做出相應(yīng)的數(shù)值運算。工程師站負責監(jiān)控整個系統(tǒng)的運行狀態(tài),可以查詢每個設(shè)備的實時數(shù)據(jù)、歷史數(shù)據(jù);當系統(tǒng)出現(xiàn)故障時,數(shù)據(jù)服務(wù)系統(tǒng)及時發(fā)送故障設(shè)備,工程師站接收報警信息后根據(jù)規(guī)程進行操作,解決系統(tǒng)出現(xiàn)的故障。監(jiān)控系統(tǒng)拓撲結(jié)構(gòu)如圖1所示。

圖1 監(jiān)控系統(tǒng)拓撲圖

2.2 監(jiān)控系統(tǒng)邏輯結(jié)構(gòu)設(shè)計

隨著網(wǎng)絡(luò)技術(shù)的發(fā)展,分布對象技術(shù)和多層體系結(jié)構(gòu)緊密結(jié)合[2]。在分布式環(huán)境中,應(yīng)用程序不再以整體的形式提供給用戶,而是將程序分成N層,用戶程序可以訪問運行在網(wǎng)絡(luò)的各個服務(wù)對象。根據(jù)以上思想,將CORBA中間件技術(shù)和監(jiān)控系統(tǒng)結(jié)合起來形成強大的服務(wù)平臺是可行的。本文設(shè)計了基于CORBA的監(jiān)控系統(tǒng)邏輯結(jié)構(gòu),如圖2所示。

硬件、操作系統(tǒng)和網(wǎng)絡(luò)層:底層硬件、操作系統(tǒng)層,以及CORBA支持的任意網(wǎng)絡(luò)結(jié)構(gòu)。

CORBA中間件:提供底層網(wǎng)絡(luò)通信服務(wù)。通過對象請求代理,可以實現(xiàn)不同底層網(wǎng)絡(luò)協(xié)議之間的數(shù)據(jù)通信。

服務(wù)層:基于CORBA中間件提供的命名服務(wù)、數(shù)據(jù)服務(wù)、時間服務(wù)等,為整個系統(tǒng)運行提供服務(wù)支撐。向上為應(yīng)用層程序提供API接口服務(wù),保證程序間的獨立運行,向下使用CORBA提供的基礎(chǔ)服務(wù)和通信機制實現(xiàn)各個服務(wù)間的數(shù)據(jù)通信與共享。在基于CORBA通信服務(wù)的基礎(chǔ)上,系統(tǒng)的實時數(shù)據(jù)庫、歷史數(shù)據(jù)庫和計算服務(wù)存儲現(xiàn)場數(shù)據(jù),為應(yīng)用層提供基礎(chǔ)數(shù)據(jù)源。

應(yīng)用層:基于服務(wù)層之上,在系統(tǒng)運行時獨立CORBA對象存在。包括監(jiān)控系統(tǒng)、日志系統(tǒng)、圖形顯示系統(tǒng)等應(yīng)用系統(tǒng)。

2.3 監(jiān)控系統(tǒng)功能設(shè)計

監(jiān)控系統(tǒng)功能可分為通信系統(tǒng)、人機界面系統(tǒng)、數(shù)據(jù)采集系統(tǒng)和數(shù)據(jù)服務(wù)系統(tǒng)四部分,如圖3所示。

圖2 監(jiān)控系統(tǒng)邏輯結(jié)構(gòu)圖

圖3 監(jiān)控系統(tǒng)功能結(jié)構(gòu)圖

通信系統(tǒng):負責整個監(jiān)控系統(tǒng)的數(shù)據(jù)通信,采用遠程接口調(diào)用和數(shù)據(jù)推送兩種工作模式。用戶通過客戶端代理模塊遠程請求服務(wù)器數(shù)據(jù),服務(wù)器模塊響應(yīng)并根據(jù)接口返回請求數(shù)據(jù),實現(xiàn)兩者數(shù)據(jù)通信。數(shù)據(jù)推送模式是指用戶程序調(diào)用數(shù)據(jù)推送模塊并將信息發(fā)送到事件通道,其他模塊接收事件通道信息,實現(xiàn)數(shù)據(jù)主動發(fā)送功能。

人機界面系統(tǒng):系統(tǒng)運行在工程師站,主要包括用戶管理、數(shù)據(jù)顯示及查詢、日志報警以及報表等模塊,可以實時監(jiān)測系統(tǒng)運行狀況,并可查詢歷史數(shù)據(jù)信息、日志信息;當系統(tǒng)發(fā)生故障時,界面會及時發(fā)出報警信息,提醒用戶處理故障。

數(shù)據(jù)采集系統(tǒng):系統(tǒng)運行在現(xiàn)場工作站中,主要負責采集現(xiàn)場設(shè)備的實時數(shù)據(jù),并將數(shù)據(jù)發(fā)送到數(shù)據(jù)服務(wù)器中;當人機界面有操作IO設(shè)備指令時,數(shù)據(jù)采集系統(tǒng)負責將指令下發(fā)到對應(yīng)的IO設(shè)備中,實現(xiàn)對現(xiàn)場設(shè)備的遠程控制。

數(shù)據(jù)服務(wù)系統(tǒng):系統(tǒng)運行在數(shù)據(jù)服務(wù)器中,分為實時數(shù)據(jù)、歷史數(shù)據(jù)和數(shù)據(jù)備份等數(shù)據(jù)存儲模塊,為人機界面系統(tǒng)提供數(shù)據(jù)源。數(shù)據(jù)服務(wù)系統(tǒng)將實時數(shù)據(jù)不斷的推送到事件通道,人機界面系統(tǒng)接收實時數(shù)據(jù)并顯示在界面中;系統(tǒng)定期備份現(xiàn)場數(shù)據(jù),防止重要數(shù)據(jù)丟失。

3.監(jiān)控系統(tǒng)的實現(xiàn)

考慮到工業(yè)現(xiàn)場設(shè)備控制的復雜性、分散性以及較為惡劣的環(huán)境等問題,本文設(shè)計并實現(xiàn)了基于CORBA技術(shù)的局域網(wǎng)監(jiān)控系統(tǒng),具備跨操作系統(tǒng)、跨編程語言操作,實現(xiàn)遠程控制、實時監(jiān)測等功能,可減少工作人員不必要現(xiàn)場設(shè)備巡視及操作,極大的方便了人工操作。

3.1 基于CORBA應(yīng)用程序開發(fā)的步驟

基于CORBA的分布式應(yīng)用程序開發(fā)要求客戶端和服務(wù)器端的通信必須經(jīng)過特殊的中間層來實現(xiàn)[3],其開發(fā)步驟如下:

(1)確定程序?qū)ο螅⒍x它們在IDL文件的接口;

(2)編譯接口文件,系統(tǒng)自動生成客戶端和服務(wù)器端代碼;

(3)在ORB調(diào)度請求前,實例化CORBA對象的伺服類;

(4)編寫客戶端代理請求程序,并鏈接成客戶實現(xiàn)文件;

(5)編寫服務(wù)器端接口實現(xiàn)程序,鏈接成服務(wù)器實現(xiàn)文件。

下面用IDL定義了系統(tǒng)常用數(shù)據(jù)類型:

//IDL

module SI

{

typedef char siChar;

typedef unsigned short ? ?siUChar;

typedef char siByte ;

typedef char siBool;

typedef char siInt8;

typedef char siUInt8;

typedef short ? ? ? ? siInt16;

typedef unsigned short ? ?siUInt16;

typedef long ? ? ? ? ? ? ?siInt32;

typedef unsigned long ? ? siUInt32;

struct siTime

{

siUInt32 ? Second;

siUInt16 ?Millisec;

};

struct siVariant

{

siUInt8 ? ?DataType;

siVal ? ? ?val;

};

struct siData

{

siTime ? ? ?time; ? ? ?siVariant ? value;

siChar ? ? quality;

};

struct siRealData

{

siUInt32 tagId;

siData ? rData;

};

//讀數(shù)據(jù)和寫數(shù)據(jù)接口函數(shù)

bool readData (........);

bool writeData (........);

}

3.2 服務(wù)器端功能實現(xiàn)

除了IDL接口定義和生成的Skeleton類,服務(wù)器端接口類實現(xiàn)接口函數(shù),接口類繼承框架文件伺服類。

服務(wù)器端程序?qū)崿F(xiàn)包括兩部分,一部分是接口定義的函數(shù)的實現(xiàn)。

class si_i : public POA_SI::SI

{

public:

si_i ();

virtual ?~DB_i();

virtual ::SI::bool readData (........);

virtual ::SI::bool writeData (........);

};

服務(wù)器端定義類si_i,繼承了伺服類POA_SI,并實現(xiàn)伺服類中的數(shù)據(jù)接口函數(shù)。

另一部分包括對象程序,需調(diào)用對象接口來實現(xiàn)具體功能。在編寫服務(wù)器程序時,需要初始化CORBA環(huán)境,首先要初始化ORB,本文通過命名服務(wù)實現(xiàn)對象實例的綁定與查找。下面是初始化ORB代碼:

this->orb_ = CORBA::ORB_init(argc, argv);

CORBA::Object_ptr poa_object = this->orb_->resolve_initial_references ("RootPOA");

this->root_poa_ = PortableServer: :POA::_narrow(poa_object);

PortableServer::POAManager_var poa_manager = root_poa_->the_POAManager();

poa_manager->activate();

服務(wù)器將對象實例綁定到命名服務(wù),如下代碼所示:

CosNaming::Name objectName;

objectName.length(1);

objectName[0].id =”connname”;

objectName[0].kind = “connkind”;

try

{

naming_context_->bind(objectName, objref);

}

服務(wù)器端將對象名ID為“conname”,類型為”connkind”的實例綁定到命名服務(wù)中,等待客戶端通過對象名獲取對象實例。

3.3 客戶端功能實現(xiàn)

在本系統(tǒng)中,客戶端應(yīng)用程序主要是查詢和調(diào)控操作,通過ORB調(diào)用服務(wù)器端的具體方法來實現(xiàn)具體操作。ORB主要完成客戶對象的獲取請求,獲取服務(wù)端的返回值,并顯示在人機界面系統(tǒng)中。下面是客戶端ORB通過命名服務(wù),獲取服務(wù)器端的對象實例。

CosNaming::Name objectName;

objectName.length(1);

objectName[0].id = ”connname”;

objectName[0].kind = “connkind”;

try

{

return naming_context_->resolve(object Name);

}

客戶端獲取對象實例,并使用接口函數(shù)實現(xiàn)與服務(wù)器端的數(shù)據(jù)通信,代碼如下:

Class Class_si * my_si = new Class_si();

my_si->SI_Ref_->readData(......);

4.總結(jié)

基于CORBA技術(shù)的局域網(wǎng)監(jiān)控系統(tǒng)不用考慮通信協(xié)議和平臺差異,只要按照CORBA統(tǒng)一規(guī)范,根據(jù)各自的平臺進行編譯即可;系統(tǒng)具有可移植性、可重用性和可擴展性等特點。隨著我國工業(yè)自動化水平的不斷提高,降低能耗、提高設(shè)備利用率和生產(chǎn)效率、改善工人勞動條件將是企業(yè)發(fā)展的方向,相信本系統(tǒng)會有很大的應(yīng)用前景。

參考文獻

[1]胡新榮.分布式對象技術(shù)的研究[J].武漢科技學院學報,2002(03).

[2]楊燕.基于CORBA的自適應(yīng)軟總線設(shè)計技術(shù)[J].西北工業(yè)大學計算機應(yīng)用技術(shù),2002.

[3]高建軍,吳健.CORBA服務(wù)在分布式電力監(jiān)控系統(tǒng)中的應(yīng)用[J].計算機應(yīng)用與軟件,2005(05).

[4]楊妮妮,楊進.基于CORBA事件服務(wù)的煤礦安全生產(chǎn)監(jiān)控系統(tǒng)聯(lián)網(wǎng)方案[J].礦業(yè)研究與開發(fā),2008(04).

[5]葉雙,傅清祥.基于CORBA的異步通訊服務(wù)[J].福州大學學報(自然科學版),2001(04).

[6]薛文玲,張紹華,李天柱.CORBA在遠程控制中的應(yīng)用[J].計算機應(yīng)用研究,2001(09).

[7]李麗娟.基于CORBA的分布式監(jiān)控系統(tǒng)開發(fā)[D].四川大學,2006.

[8]聶晶.基于PLC的供熱網(wǎng)絡(luò)遠程監(jiān)控系統(tǒng)研究[D].新疆大學,2007.

[9]彭宏,韓仲平.基于CORBA的非耦合異步多點通訊——CORBA的事件服務(wù)和通知服務(wù)[J].計算機工程與應(yīng)用,2000(07).

作者簡介:陳嬙嬙(1985—),女,華北電力大學在讀碩士研究生,主要研究方向:局域網(wǎng)監(jiān)控系統(tǒng)。

主站蜘蛛池模板: 成年人久久黄色网站| 国产精品久久久久久久伊一| 欧美a在线视频| 伊人天堂网| 日本人妻丰满熟妇区| 草草影院国产第一页| 亚洲第一网站男人都懂| 久草热视频在线| 亚洲男人的天堂久久香蕉网| 国产免费观看av大片的网站| 幺女国产一级毛片| 亚洲AV无码久久天堂| 91娇喘视频| 亚卅精品无码久久毛片乌克兰| 日韩欧美高清视频| 国产日韩久久久久无码精品| 中国美女**毛片录像在线| 国产乱子精品一区二区在线观看| 啪啪啪亚洲无码| 99视频在线观看免费| 亚洲欧美成人| 97se亚洲综合在线| 在线观看无码a∨| 国产伦精品一区二区三区视频优播 | 日韩精品一区二区三区中文无码 | 一级福利视频| 99精品视频九九精品| 欧美日韩精品在线播放| 亚洲av无码成人专区| 免费a在线观看播放| 国产午夜不卡| 97亚洲色综久久精品| 欧美在线视频不卡第一页| 91免费精品国偷自产在线在线| 成人字幕网视频在线观看| 亚洲欧洲天堂色AV| 亚洲人成在线精品| 午夜综合网| 9966国产精品视频| 亚洲性日韩精品一区二区| 国产一级二级在线观看| 久久国产高清视频| 青青青国产视频| 深夜福利视频一区二区| 伊人激情久久综合中文字幕| 中文字幕 日韩 欧美| 无码中文字幕精品推荐| 99精品热视频这里只有精品7| 国产在线精品网址你懂的| 欧美成人区| 波多野结衣中文字幕一区| 97se亚洲综合| 久久综合伊人 六十路| 国产91视频免费| 九九热精品视频在线| 好紧太爽了视频免费无码| 国产肉感大码AV无码| 大香网伊人久久综合网2020| 国产杨幂丝袜av在线播放| 久草网视频在线| аⅴ资源中文在线天堂| 色九九视频| 91精品网站| 91亚洲精品国产自在现线| 国产精品免费电影| 中文字幕无码av专区久久| 色综合久久综合网| 亚洲成A人V欧美综合天堂| 国产精品观看视频免费完整版| 四虎永久在线视频| 欧美在线导航| 欧美成人一级| 成人在线观看不卡| 日本欧美一二三区色视频| 视频国产精品丝袜第一页| 天堂久久久久久中文字幕| 国产福利一区二区在线观看| 五月婷婷综合在线视频| 中文字幕色在线| 婷婷五月在线| 精品自窥自偷在线看| 2019国产在线|