基于Berkeley DB的機房環(huán)境監控系統
引言
隨著(zhù)社會(huì )信息化進(jìn)程的發(fā)展,許多行業(yè)部門(mén)的中心機房設備和規模也日趨擴大,配套的環(huán)境設備也日益增多,一旦機房的環(huán)境設備出現故障,將直接影響計算機系統的安全運行,后果不堪設想。為了保證安全,對機房的環(huán)境設備進(jìn)行自動(dòng)監控是極其重要的。
1 機房環(huán)境設備監控的主要內容及基本功能
機房環(huán)境設備監控的主要內容有:機房用電的檢測;對機房低壓配電柜,UPS電源設備的輸入端和輸出端,各回路的電壓、電流、頻率、電功率的監測;溫度、濕度的監測;機房漏水的監測;消防的監測。
通過(guò)對機房環(huán)境設備特點(diǎn)的分析,可把機房環(huán)境監控系統的基本功能概括為:現場(chǎng)數據的實(shí)時(shí)采集、發(fā)送和顯示;對采集到的數據進(jìn)行處理和存儲;對數據處理的結果進(jìn)行分析、判斷和報警;提供多種業(yè)務(wù)支持等。
2 監控系統對數據庫的要求
由于該監控系統的信息吞吐量大,多用戶(hù)數據共享,實(shí)時(shí)性強等需求特點(diǎn),對數據的存儲與處理宜采用數據庫方式。監控系統需要24 h不間斷地進(jìn)行監控,而數據采集系統更是要求在長(cháng)期無(wú)人值守的情況下連續工作,因此,可靠性和穩定性便成為整個(gè)系統首要考慮的問(wèn)題。監控主機一旦發(fā)生斷電,通信故障,甚至系統崩潰等突發(fā)事件,在修復后應能從數據采集物理存儲介質(zhì)中獲得不少于15天的原始數據,這些數據在時(shí)間上必須是連續的,而且必須持續到系統故障前的一個(gè)文件保存周期內。為達到上述要求,必須在數據采集系統中裝載一個(gè)嵌入式數據庫。
3 嵌入式數據庫Berkeley DB簡(jiǎn)介
3.1 Berkeley DB的特點(diǎn)
Berkeley DB是開(kāi)放源代碼的嵌入式數據庫,為數據訪(fǎng)問(wèn)和管理提供了簡(jiǎn)單API函數調用,并支持包括C,C++,Java,Perl,TCL,Pyth on和PHP等的多種編程語(yǔ)言。Berkeley DB作為一種嵌入式數據庫系統在許多方面有著(zhù)獨特的優(yōu)勢。首先,由于其應用程序和數據庫管理系統運行在相同的進(jìn)程空間中,耗費在通信上的開(kāi)銷(xiāo)降低到了極低程度。其次,它使用簡(jiǎn)單的函數調用接口來(lái)完成所有的數據庫操作,而不是在數據庫系統中經(jīng)常用到的SQL語(yǔ)言,避免了對結構化查詢(xún)語(yǔ)言進(jìn)行解析和處理所需的開(kāi)銷(xiāo)。
3.2 Berkeley DB數據庫操作
通過(guò)內嵌在程序中的函數庫完成對數據的保存,查詢(xún),修改和刪除等操作。對它的操作要調用專(zhuān)用的API實(shí)現,這些API提供了查詢(xún),插入,刪除等功能。比如com.sleepycat.db.Db類(lèi)代表數據庫對象。Db類(lèi)的put()方法完成的是插入功能;get()完成的是獨處數據的功能;com.sleepycat.db.Dbc是游標類(lèi),提供了遍歷數據庫記錄的功能。
Berkeley DB提供了數據庫句柄結構DB,數據庫記錄結構DBT,數據庫游標結構DBC,數據庫環(huán)境句柄結構DB_ENV,數據庫操作函數,如數據庫創(chuàng )建函數:DB→open();數據庫些函數DB→put()等,通過(guò)對這些函數的調用實(shí)現了對數據庫復雜的管理操作。
4 Berkeley DB在ARM環(huán)境下的建立
4.1 Berkeley DB在Linux系統下的安裝
Berkeley DB源碼以在官方網(wǎng)站上下載。建立宿主機-目標機的模式,宿主機上安裝Linux操作系統和交叉編譯器,對程序代碼進(jìn)行交叉編譯,鏈接,形成在目標機上可以運行的二進(jìn)制代碼,然后把可執行代碼文件下載到目標機上運行。
?。?)將cross 2.9.5.3交叉工具鏈安裝在/usr/bcal/arm/路徑下,并下載Berkeley DB的最新版本,建立好交叉編譯器后,對下載的Berkeley DB程序包準備安裝。
c++相關(guān)文章:c++教程
評論