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)復(fù)雜,存在著同一網(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è)備控制的復(fù)雜性、分散性以及較為惡劣的環(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)。

主站蜘蛛池模板: 在线观看国产黄色| 久久国产黑丝袜视频| 久久青草精品一区二区三区| 国产真实自在自线免费精品| 国产91视频免费观看| 国产激情影院| 亚洲无码在线午夜电影| 免费看黄片一区二区三区| 狠狠ⅴ日韩v欧美v天堂| 国产欧美精品一区二区| 色爽网免费视频| 免费看美女毛片| 精品国产aⅴ一区二区三区| 婷婷亚洲视频| 中文成人无码国产亚洲| 在线视频精品一区| 香蕉精品在线| 欧美日韩亚洲综合在线观看| 日本人真淫视频一区二区三区| 亚洲高清日韩heyzo| 97在线观看视频免费| 国产精品短篇二区| 一本大道东京热无码av| 她的性爱视频| 本亚洲精品网站| 欧美综合成人| 天天色综网| 亚洲欧美激情小说另类| 老司机午夜精品网站在线观看| 国产超碰一区二区三区| 美女扒开下面流白浆在线试听| 毛片视频网址| 特级毛片免费视频| 亚洲成人黄色网址| 国产99视频在线| 伊人中文网| 欧美精品H在线播放| 国产精品刺激对白在线| 亚洲一区二区成人| 久久免费视频6| 69av免费视频| 日本不卡在线| 色窝窝免费一区二区三区| 全裸无码专区| 国产香蕉在线| 一级一级一片免费| 4虎影视国产在线观看精品| 中国美女**毛片录像在线| 精品日韩亚洲欧美高清a| 亚洲第一区欧美国产综合| 青青青国产视频| 青青青草国产| 久热精品免费| 国产福利在线免费| 日本免费a视频| 欧美五月婷婷| 免费一级毛片在线观看| 97影院午夜在线观看视频| 国产区91| 人妻中文字幕无码久久一区| 欧美午夜网站| 日韩高清一区 | 国产精品免费福利久久播放 | 国产亚洲精品在天天在线麻豆 | 国内精品久久久久久久久久影视| 日本国产精品| 亚洲大尺码专区影院| 久久不卡国产精品无码| 黄色国产在线| 五月婷婷精品| 久久亚洲国产最新网站| 少妇人妻无码首页| 91麻豆精品视频| 日韩成人在线网站| 欧美成人一级| 国产91久久久久久| 九色在线观看视频| 亚洲Va中文字幕久久一区| 精品国产黑色丝袜高跟鞋| 亚洲精品无码在线播放网站| 在线观看欧美精品二区| 亚洲一本大道在线|