網(wǎng)絡(luò)安全設(shè)備聯(lián)動(dòng)中小文件存儲(chǔ)優(yōu)化方法論文
摘要:網(wǎng)絡(luò)系統(tǒng)在運(yùn)行過程中會(huì)產(chǎn)生大量日志,采用Java編程技術(shù)將各安全設(shè)備日志轉(zhuǎn)換為XML文件。在對(duì)日志文件存儲(chǔ)過程中,現(xiàn)有的存儲(chǔ)系統(tǒng)硬件成本高,擴(kuò)展能力差,數(shù)據(jù)并行訪問效率低,難以滿足網(wǎng)絡(luò)安全設(shè)備聯(lián)動(dòng)系統(tǒng)的需求。因此,該文采用基于HDFS的云存儲(chǔ)系統(tǒng)對(duì)日志文件進(jìn)行存儲(chǔ)。為了提高基于HDFS的云存儲(chǔ)系統(tǒng)中小文件存儲(chǔ)效率,該文設(shè)計(jì)了云存儲(chǔ)系統(tǒng)中小文件存儲(chǔ)的優(yōu)化方案,主要在小文件合并和小文件檢索方面做了優(yōu)化。該方案結(jié)合網(wǎng)絡(luò)安全設(shè)備聯(lián)動(dòng)系統(tǒng)中日志文件的特點(diǎn),首先是根據(jù)不同設(shè)備的文件進(jìn)行分類,然后根據(jù)小文件在合并后的大文件中的偏移量進(jìn)行檢索。最后采用3組文件集合對(duì)優(yōu)化方案進(jìn)行了測(cè)試,實(shí)驗(yàn)結(jié)果表明,在不影響存儲(chǔ)系統(tǒng)運(yùn)行狀況的基礎(chǔ)上,該方案提高了小文件的存儲(chǔ)效率和讀取效率。
關(guān)鍵詞:網(wǎng)絡(luò)安全;小文件;Hadoop;存儲(chǔ)優(yōu)化
中圖分類號(hào):TP393 文獻(xiàn)標(biāo)識(shí)碼:A 文章編號(hào):1009-3044(2015)35-0010-02
1引言
網(wǎng)絡(luò)系統(tǒng)在運(yùn)行過程中會(huì)產(chǎn)生大量的系統(tǒng)日志、應(yīng)用日志、安全日志和網(wǎng)絡(luò)日志,這些日志包含著關(guān)于網(wǎng)絡(luò)運(yùn)行、安全及狀態(tài)的數(shù)據(jù)。隨著采集日志的大規(guī)模增長(zhǎng),現(xiàn)有的存儲(chǔ)系統(tǒng)硬件成本高,擴(kuò)展能力差,數(shù)據(jù)并行訪問效率低,難以滿足網(wǎng)絡(luò)安全設(shè)備聯(lián)動(dòng)系統(tǒng)的需求。因此,提供一種更高性能、更低成本、更好可靠性的易于管理的存儲(chǔ)平臺(tái),才能夠幫助該系統(tǒng)用盡可能低的成本應(yīng)對(duì)日益增長(zhǎng)的數(shù)據(jù)存儲(chǔ)需求。HDFS采用主從式架構(gòu)設(shè)計(jì)模式(master/slave),一個(gè)名稱節(jié)點(diǎn)(NameNode)和若干數(shù)據(jù)節(jié)點(diǎn)(DataNode)構(gòu)成HDFS集群[1]。HDFS的這種單名稱節(jié)點(diǎn)的設(shè)計(jì)極大地簡(jiǎn)化了文件系統(tǒng)的結(jié)構(gòu),然而也因此引發(fā)了HDFS的小文件存儲(chǔ)效率低的問題。HDFS設(shè)計(jì)之初的目的是存儲(chǔ)大量的大文件,所以需要采用分塊策略先將每個(gè)文件分塊,保存機(jī)制是每個(gè)文件都占用一個(gè)或多個(gè)塊。因?yàn)镠DFS中的每個(gè)目錄和文件的元數(shù)據(jù)信息都存放在名稱節(jié)點(diǎn)的內(nèi)存中,如果系統(tǒng)中存在大量的小文件(指那些比HDFS數(shù)據(jù)塊(默認(rèn)為64MB)小得多的文件),則無疑會(huì)降低整個(gè)存儲(chǔ)系統(tǒng)的存儲(chǔ)效率和存儲(chǔ)能力。然而,在網(wǎng)路安全設(shè)備聯(lián)動(dòng)系統(tǒng)[2]存在著大量的小文件。大量的小文件存在于云存儲(chǔ)系統(tǒng)中無疑會(huì)降低整個(gè)系統(tǒng)的I/O性能。針對(duì)這一問題,本文提出云存儲(chǔ)中小文件的合并處理方法,以提高小文件的存儲(chǔ)效率,提高整個(gè)系統(tǒng)的I/O性能。
2整體方案優(yōu)化設(shè)計(jì)
文件的優(yōu)化方案主要包括4個(gè)部分:數(shù)據(jù)預(yù)存儲(chǔ)節(jié)點(diǎn)的功能設(shè)計(jì),小文件合并方案,小文件索引結(jié)構(gòu)的設(shè)計(jì)以及小文件合并過程的整體設(shè)計(jì)。
2.1數(shù)據(jù)預(yù)存儲(chǔ)節(jié)點(diǎn)功能設(shè)計(jì)
數(shù)據(jù)預(yù)存儲(chǔ)節(jié)點(diǎn)是在HDFS架構(gòu)的基礎(chǔ)上新增的節(jié)點(diǎn),它位于客戶端與名稱節(jié)點(diǎn)和數(shù)據(jù)節(jié)點(diǎn)之間,主要實(shí)現(xiàn)對(duì)存儲(chǔ)的文件進(jìn)行預(yù)處理,根據(jù)文件大小,判斷是否屬于小文件,對(duì)于小文件主要完成存儲(chǔ)前的合并,生成索引以及小文件檢索時(shí)的文件分離等功能。增加數(shù)據(jù)預(yù)存儲(chǔ)節(jié)點(diǎn)之后,在數(shù)據(jù)存儲(chǔ)的過程中,數(shù)據(jù)的流向由從客戶端直接到數(shù)據(jù)節(jié)點(diǎn)變成了由客戶端先到預(yù)存儲(chǔ)節(jié)點(diǎn)再到數(shù)據(jù)節(jié)點(diǎn)。
2.2小文件合并算法設(shè)計(jì)
當(dāng)客戶端寫入小文件時(shí),首先根據(jù)小文件的類型對(duì)數(shù)據(jù)預(yù)存儲(chǔ)節(jié)點(diǎn)進(jìn)行分組。然后分別將每個(gè)分組中的小文件合并成大文件,此時(shí),生成相關(guān)小文件索引信息及元數(shù)據(jù)信息。最后將合并后的文件和相關(guān)的元數(shù)據(jù),按照原HDFS寫入文件的方式一同上傳至HDFS中,其中第二類元數(shù)據(jù)信息由數(shù)據(jù)預(yù)存儲(chǔ)節(jié)點(diǎn)進(jìn)行存儲(chǔ),第一類元數(shù)據(jù)信息由名稱節(jié)點(diǎn)進(jìn)行存儲(chǔ),數(shù)據(jù)節(jié)點(diǎn)存儲(chǔ)合并成的大文件[3]當(dāng)客戶端需要讀取某個(gè)小文件時(shí),從名稱節(jié)點(diǎn)獲取小文件所在大文件的元數(shù)據(jù)信息,然后從數(shù)據(jù)預(yù)存儲(chǔ)節(jié)點(diǎn)獲取第二類元數(shù)據(jù)信息,從數(shù)據(jù)節(jié)點(diǎn)獲取小文件所在的大文件,并在接口中將大文件解檔為若干小文件,并將這些小文件緩存在客戶端。為了便于算法描述,對(duì)算法里的符號(hào)進(jìn)行定義:File[type][MD5][key]——緩沖區(qū)中待合并的文件;type——日志文件的類型(1:主機(jī)日志;2:sort日志;3:防火墻日志;4:交換機(jī)日志);MD5——文件的MD5值;fi——要合并的第i個(gè)文件;xj——合并第j類文件個(gè)數(shù)。分組合并算法描述如下:(1)初始化,定義一個(gè)三維數(shù)組File[type][MD5][key],type初始化為1,key值初始化為文件的大;(2)讀入緩沖區(qū)的所有文件大小,更新數(shù)組File[type][MD5][key],根據(jù)文件的`類型更新數(shù)組的type值,初始化i=1;(3)采用冒泡排序,分別將數(shù)組File[i][MD5][key]從大到小進(jìn)行排序。首先判斷File[i][MD5][key]的大小,如果所有文件的總大小大于64M,開始進(jìn)行合并,否則退出程序,i++,等待下次分組合并調(diào)度;(4)從最大的文件fi開始分組。如果放入文件fi后,此類文件的總大小小于64M,則存放下一個(gè)文件,從數(shù)組中把文件fi的記錄刪除,循環(huán)這個(gè)過程,直到所有的File[i][MD5][key]文件都合并到一起;(5)計(jì)算每類文件合并后的大小,文件大小達(dá)到63M的調(diào)用HDFS命令將文件上傳到HDFS上,大小小于63M的文件,再從緩沖區(qū)中查找文件進(jìn)行裝入,返回(2);(6)上傳成功;主要是考慮到用戶的訪問效率,算法中采用將同類日志文件進(jìn)行分組,無論從寫入小文件,還是從讀取小文件方面,都能大大提高HDFS的性能:首先減輕了名稱節(jié)點(diǎn)的負(fù)擔(dān),在讀取小文件方面,不用連接數(shù)據(jù)節(jié)點(diǎn)讀取,減少文件讀寫的I/O操作,節(jié)約大量數(shù)據(jù)傳輸時(shí)間,極大地節(jié)省了網(wǎng)絡(luò)通信開銷,降低了HDFS的訪問壓力,提高客戶端訪問文件的速率和性能。當(dāng)用戶刪除數(shù)據(jù)時(shí),把合并后的文件取回?cái)?shù)據(jù)預(yù)存儲(chǔ)節(jié)點(diǎn),進(jìn)行分解,刪除指定文件,再與緩存區(qū)中已有的文件進(jìn)行合并。用戶查詢文件時(shí),需要對(duì)HDFS索引進(jìn)行查詢,同時(shí)也需要查詢緩沖區(qū)里面的文件。
2.3小文件索引結(jié)構(gòu)的設(shè)計(jì)
在小文件合并之后,僅僅根據(jù)名稱節(jié)點(diǎn)中存儲(chǔ)的元數(shù)據(jù)信息不能檢索到小文件,為了提高檢索效率,需要為所有小文件構(gòu)建相應(yīng)的索引,使用戶能夠通過索引快速的檢索到小文件。小文件索引信息是在小文件合并成大文件之后生成的,保存在數(shù)據(jù)預(yù)存儲(chǔ)節(jié)點(diǎn)中,通過此類元數(shù)據(jù)信息,再結(jié)合名稱節(jié)點(diǎn)中的第一類元數(shù)據(jù)信息,才能正確找到小文件的存儲(chǔ)位置。所以小文件的索引信息對(duì)于后期的小文件檢索極其重要,其中要包含小文件的一些重要信息:File_name類型為String,表示小文件名稱;File_size類型為int,表示小文件大。籉ile_type類型為int,表示小文件類型;Merge_file_nam類型為string,表示小文件合并成大文件后的名稱;File_offset類型為int,當(dāng)前小文件在合并文件中的偏移量;time類型為long,表示文件的寫入時(shí)間;If_use類型為bool,表示文件是否存在。
2.4小文件合并過程的整體設(shè)計(jì)
大致流程如下:當(dāng)需要寫入文件時(shí),首先將數(shù)據(jù)傳輸?shù)綌?shù)據(jù)預(yù)存儲(chǔ)節(jié)點(diǎn),判斷文件大小,如果文件大小超過了HDFS數(shù)據(jù)塊的大小,則直接存入數(shù)據(jù)節(jié)點(diǎn),并將元數(shù)據(jù)信息寫入到名稱節(jié)點(diǎn);如果需要寫入的文件屬于小文件,則先判斷小文件的類型,然后根據(jù)2.2中設(shè)計(jì)的小文件合并算法將小文件合并,生成索引信息,在這個(gè)合并的過程中,不斷地將正在合并的小文件索引信息插入到小文件索引信息列表中,當(dāng)合并文件塊達(dá)到合適的大小時(shí),客戶端將寫文件請(qǐng)求發(fā)送到名稱節(jié)點(diǎn)將合并后的文件存儲(chǔ)到相應(yīng)的數(shù)據(jù)節(jié)點(diǎn)中。
3實(shí)驗(yàn)驗(yàn)證
實(shí)驗(yàn)需要搭建Hadoop集群,集群中包括4個(gè)節(jié)點(diǎn):一臺(tái)Na-meNode,二臺(tái)DataNode,以及客戶端用來提交數(shù)據(jù)的NameNode。使用VMware7.0來模擬Linux環(huán)境[4,5臺(tái)機(jī)器上模擬海量小文件的存儲(chǔ)和訪問操作。本文隨機(jī)選取了10000個(gè)xml日志數(shù)據(jù)文件,文件大小分布情況為:200kB占1%,300kB占2%,400kB占10%,500kB占20%,600kB占30%,700kB占20%,800kB占10%,900kB占4%,1000kB占3%,可見文件大小集中在400kb到1000kb之間。為了直觀的反應(yīng)優(yōu)化方案在處理小文件和大文件時(shí)的系統(tǒng)性能,本文在測(cè)試數(shù)據(jù)中分別選取了100、1000、10000組數(shù)據(jù),按照以上測(cè)試和執(zhí)行程序步驟,對(duì)文件寫入時(shí)間進(jìn)行測(cè)試,測(cè)試結(jié)果如圖1所示。實(shí)驗(yàn)結(jié)果表明,隨著文件數(shù)量的增多,寫入文件所用時(shí)間增長(zhǎng)趨勢(shì)的變化緩慢,說明本文設(shè)計(jì)的Hadoop小文件存儲(chǔ)優(yōu)化方案在寫入海量小文件時(shí)性能更高。
4結(jié)論
本文首先對(duì)網(wǎng)絡(luò)安全設(shè)備聯(lián)動(dòng)系統(tǒng)的數(shù)據(jù)轉(zhuǎn)化為XML文檔,然后對(duì)文件的特點(diǎn)及文件大小的分布進(jìn)行了分析。針對(duì)HDFS對(duì)小文件存儲(chǔ)效率低的問題,對(duì)小文件存儲(chǔ)方案進(jìn)行了優(yōu)化,設(shè)計(jì)了小文件分組合并的算法。最后搭建了Hadoop集群環(huán)境,對(duì)改進(jìn)的方案進(jìn)行測(cè)試,實(shí)驗(yàn)結(jié)果表明,本文設(shè)計(jì)的Hadoop小文件存儲(chǔ)優(yōu)化方案在寫入文件所用時(shí)間增長(zhǎng)趨勢(shì)的變化緩慢,說明本方案在寫入海量小文件時(shí)具有很高的性能,在不影響存儲(chǔ)系統(tǒng)運(yùn)行狀況的基礎(chǔ)上,該方案提高了小文件的存儲(chǔ)效率和讀取效率。
參考文獻(xiàn):
[1]廖彬,于炯,張?zhí)?楊興耀.基于分布式文件系統(tǒng)HDFS的節(jié)能算法[J].計(jì)算機(jī)學(xué)報(bào),2013(05):1047-1064.
[2]傅穎勛,羅圣美,舒繼武.安全云存儲(chǔ)系統(tǒng)與關(guān)鍵技術(shù)綜述[J].計(jì)算機(jī)研究與發(fā)展,2013,50(1):136-145
[3]DLTennenhouse,JMSmith,WDSincoskie,etal.ASurveyofActiveNetworksResearch[J].IEEECommunicationsMagazine,1997,35(l):80-86.
[4]許春玲,張廣泉.分布式文件系統(tǒng)HadoopHDFS與傳統(tǒng)文件系統(tǒng)LinuxFS的比較與分析[J].蘇州大學(xué)學(xué)報(bào)(工科版),2010,04:5-9+19.
[5]崔杰,李陶深,蘭紅星.基于Hadoop的海量數(shù)據(jù)存儲(chǔ)平臺(tái)設(shè)計(jì)與開發(fā)[J].計(jì)算機(jī)研究與發(fā)展,2012(S1):12-18.
【網(wǎng)絡(luò)安全設(shè)備聯(lián)動(dòng)中小文件存儲(chǔ)優(yōu)化方法論文】相關(guān)文章:
網(wǎng)絡(luò)存儲(chǔ)技術(shù)論文03-29
gsm網(wǎng)絡(luò)優(yōu)化論文02-25
淺談通過文件的網(wǎng)絡(luò)存儲(chǔ)培養(yǎng)學(xué)生信息管理意識(shí)的能力論文10-28
網(wǎng)絡(luò)存儲(chǔ)技術(shù)比較研究論文11-07
移動(dòng)網(wǎng)絡(luò)優(yōu)化論文03-10
探析網(wǎng)絡(luò)存儲(chǔ)技術(shù)研究論文11-07