賀道德,胡如會
貴州工程應(yīng)用技術(shù)學(xué)院 信息工程學(xué)院,貴州 畢節(jié) 551700
云計算是基于Internet來共享軟硬件資源與數(shù)據(jù)的一種計算方式[1-2],它運用虛擬的方式來整合資源,以實現(xiàn)用戶便捷地使用共享資源. 目前,云計算中的服務(wù)與資源都由服務(wù)提供商控制,具有較好的可靠性與可控性,但由于云資源由少數(shù)服務(wù)提供商壟斷,使得云的可擴(kuò)展性不好,且成本偏高. 對等計算整合互聯(lián)網(wǎng)中用戶提供的資源來實現(xiàn)資源的共享,各用戶的地位對等,資源的利用率高,且網(wǎng)絡(luò)的可擴(kuò)展性好[3];但由于對等網(wǎng)絡(luò)中的用戶具有會話異構(gòu)等特征,使得網(wǎng)絡(luò)穩(wěn)定性和可控性不夠好. 由上述描述可知,對等計算技術(shù)和云計算技術(shù)相互補;運用對等計算技術(shù)架構(gòu)底層網(wǎng)絡(luò),可充分利用資源且可擴(kuò)展性好;然后利用云計算的虛擬技術(shù)以確保服務(wù)的可靠性與可用性,從而形成了對等云技術(shù)[4-6].
運用結(jié)構(gòu)化的對等計算系統(tǒng)構(gòu)成的對等云采用分布式哈希表[7](DHT,Distributed Hash Table)來進(jìn)行資源的發(fā)布與定位. 在資源發(fā)布時,先將資源關(guān)鍵字運用哈希算法(例如 SHA-1)計算出對象標(biāo)識objId,然后將資源發(fā)布到與節(jié)點標(biāo)識nodeId相近的節(jié)點上;在資源搜索時,亦依據(jù)哈希值來搜索. 由于哈希算法往往將屬性值相近的資源映射成完全不相關(guān)的objId,然后將其發(fā)布到不相關(guān)的節(jié)點上,從而使其難以支持資源關(guān)鍵字區(qū)間搜索. 為實現(xiàn)在結(jié)構(gòu)化對等云系統(tǒng)中進(jìn)行區(qū)間搜索,本文提出如下思想:在資源發(fā)布時,運用同態(tài)加密[8-10]具有在密文狀態(tài)下可進(jìn)行操作的特征,首先將屬性值VALUE使用具有同態(tài)特性的加密算法計算出FHVALUE,并運用此值計算出一個資源標(biāo)記,擁有相似屬性值的資源具有相同的資源標(biāo)記;然后,再哈希FHVALUE得到objId,并將資源發(fā)布到對應(yīng)nodeId的節(jié)點上;節(jié)點除存儲資源外,還需依據(jù)資源標(biāo)記將相同標(biāo)記的資源節(jié)點鏈接成資源路由環(huán). 在區(qū)間搜索時,運用同態(tài)加密過的屬性值計算出資源標(biāo)記,從而進(jìn)行區(qū)間搜索. 為實現(xiàn)上述思想,本文采用典型的結(jié)構(gòu)化對等系統(tǒng)Pastry[11]來構(gòu)建對等云,運用同態(tài)加密算法GSW[12]來計算資源標(biāo)記從而形成資源路由環(huán).
萊斯大學(xué)與微軟研究院共同提出的Pastry是采用DHT構(gòu)造的結(jié)構(gòu)化對等系統(tǒng). 該系統(tǒng)中的每個節(jié)點都擁有一個128 b的nodeId,且為自組織重疊網(wǎng)絡(luò). 節(jié)點的nodeId在節(jié)點空間中(0~2128-1)標(biāo)識節(jié)點的位置,由于散列值的隨機(jī)性,使得節(jié)點nodeId在節(jié)點空間中能均勻分布. 當(dāng)需要發(fā)布資源時,對資源屬性值運用散列算法計算出資源objId,然后運用Pastry的路由算法將資源發(fā)布到節(jié)點nodeId與資源objId在數(shù)值上最接近的那個節(jié)點;在資源定位時,按此路由算法查找資源. 由于Pastry具有完全分布式特性,且自組織、擴(kuò)展性好,因此,用其作為云系統(tǒng)的底層架構(gòu),可克服普通云系統(tǒng)擴(kuò)展性不好、成本高的不足.
在Pastry系統(tǒng)中,每個節(jié)點維護(hù)3個狀態(tài)表,包括一個路由表(R,Routing Table),一個鄰居節(jié)點集(N,Neighborhood Set)和一個葉子節(jié)點集(L,Leaf Set). 系統(tǒng)運用上述狀態(tài)表來維護(hù)網(wǎng)絡(luò)的拓?fù)湫畔?,文獻(xiàn)[11]列舉了節(jié)點標(biāo)識為10233102的狀態(tài)表,如圖1所示.
圖1 節(jié)點標(biāo)識為10233102的狀態(tài)表
圖1中描述的節(jié)點標(biāo)識為10233102,標(biāo)識的構(gòu)成采用2b進(jìn)制,b取值為2. 路由表R中的每行包含2b-1個表項,R中的第n行的節(jié)點標(biāo)識和當(dāng)前節(jié)點標(biāo)識的前n位相同(n從0開始). 葉子節(jié)點集L存儲的節(jié)點標(biāo)識與當(dāng)前節(jié)點標(biāo)識值相近,其中包含兩部分,前半部分的值略大于當(dāng)前節(jié)點標(biāo)識,后半部分的值則略小于當(dāng)前節(jié)點標(biāo)識. 鄰居節(jié)點集N存放與當(dāng)前節(jié)點物理位置相近的節(jié)點的nodeId,它主要用于維護(hù)路由的本地性[13],在正常路由過程中并不被使用.
在Pastry系統(tǒng)中,若當(dāng)前節(jié)點V收到一條路由信息,則首先從葉子節(jié)點集L中查找與路由信息中目標(biāo)節(jié)點D的節(jié)點標(biāo)識更接近的nodeId,若查找到,則路由到此節(jié)點. 第二步,在葉子節(jié)點中查找失敗的情況下,轉(zhuǎn)去查路由表R,計算出目標(biāo)節(jié)點D與當(dāng)前節(jié)點V的相同前綴長度j. 第三步,如果R中第j行的第Dj表項(Dj為目標(biāo)節(jié)點標(biāo)識中的第j個數(shù)值)不為空,則路由到此節(jié)點去. 第四步,若查找路由表失敗,則從3個狀態(tài)集中找一個和目標(biāo)節(jié)點D標(biāo)識最接近的節(jié)點,并路由到此節(jié)點. Pastry的路由算法(PR,Pastry Routing)如下所示.
R(i,j):表示路由表R中第j行第i項
Li:表示葉子節(jié)點集L中第i項存儲的節(jié)點標(biāo)識(若為負(fù)數(shù),則表示該標(biāo)識小于當(dāng)前節(jié)點標(biāo)識)
Dj:目標(biāo)節(jié)點D的第j個數(shù)值
shl(D,V):節(jié)點D與節(jié)點V具有相同標(biāo)識的前綴長度
Function PR(nodeId D)
1){/*該算法為對等云覆蓋網(wǎng)絡(luò)Pastry的主路由算法*/
2)if(L-|L|/2<=D<=L|L|/2){/*如果目標(biāo)節(jié)點D在葉子節(jié)點集中*/
3)路由到節(jié)點Li,其中|D-Li|為最?。粆
4)else{/*葉子節(jié)點集查找失敗,則轉(zhuǎn)查路由表R*/
5)j=shl(D,V);/*計算目標(biāo)節(jié)點D與當(dāng)前節(jié)點V的相同標(biāo)識前綴長度*/
6)if(R(Dj,j)!=NULL){/* 若路由表R的第j行的第Dj項不為空*/
7)路由到R(Dj,j)所存儲的節(jié)點標(biāo)識對應(yīng)的節(jié)點;}
8)else{/*路由表查找失敗*/
9)路由到節(jié)點T,T∈L∪R∪M,shl(T,D)>=j,|T-D|<|V-D|;}}
10)/*算法結(jié)束*/}
GSW是文獻(xiàn)[12]中提出的一種基于容錯學(xué)習(xí)(Learining With Error,LWE)的同態(tài)加密方案. GSW是運用矩陣與近似特征向量構(gòu)造出的基于身份的全同態(tài)系統(tǒng),它與傳統(tǒng)同態(tài)加密方案不同的是該方案無需同態(tài)操作密鑰亦可實現(xiàn)同態(tài)加密. 其基本方案是一個基于公鑰的密碼體系,其組成包括Setup,SecretKeyGen,PublicKeyGen,Enc,Dec和MPDec這6部分.
1)Setup(1λ,1L),這是一個初始化操作. 選擇一個k位的模數(shù)q,其中,k=k(λ,L),λ為安全參數(shù),L為方案的層數(shù);格的維度值n=n(λ,L);誤差分布χ=χ(λ,L),以確保容錯學(xué)習(xí)方案的安全強(qiáng)度在攻擊情況已知條件下達(dá)到2λ. 再次,選取參數(shù)m=m(λ,L)=O(nlogq),令params=(n,q,χ,m),=?logq+1,N=(n+1)·.
2)SecretKeyGen(params),該部分用于生成私鑰,其輸入為參數(shù)params,樣本t向量隨機(jī)均勻分布在n維的Zq上,輸出的私鑰sk為向量s=(1,-t1,…,-tn)∈Zq(n+1維),并令向量v=Powersof2(s),Powersof2函數(shù)的輸入為私鑰向量s,輸出向量v用于相關(guān)同態(tài)計算.
3)PublicKeyGen(params,sk),該部分用于生成公鑰,其輸入為參數(shù)params與私鑰sk,生成一個m*n矩陣B,且隨機(jī)均勻分布在Zq上,并依據(jù)誤差分布χ選取m維誤差向量e←χm,計算出b=B·t+e,然后輸出公鑰pk=A=[b|B] (該A是在Zq上的m*(n+1)維矩陣). 由于矩陣A與私鑰向量s的乘積為誤差向量e,從而確保了密鑰的安全性.
4)Enc(params,pk,μ),該部分為加密函數(shù),μ為明文,其在空間Zq之內(nèi),pk為公鑰,params為參數(shù),其輸出為密文矩陣C.
5)Dec(params,sk,C),該部分為解密函數(shù),C為密文,sk為私鑰,params為參數(shù),它可以在足夠小的空間內(nèi)恢復(fù)出明文μ.
6)MPDec(params,sk,C),該解密函數(shù)由Micciancio 和 Peikert在文獻(xiàn)[14]中提出,它可以恢復(fù)出明文μ二進(jìn)制表示的全部有效位.
此外,GSW提供了一系列同態(tài)操作函數(shù),包括同態(tài)數(shù)乘MultConst、同態(tài)加法Add、同態(tài)乘法Mult以及同態(tài)NAND門操作等.
為了在結(jié)構(gòu)化的對等云中進(jìn)行區(qū)間搜索,本文以如下網(wǎng)絡(luò)架構(gòu)為基礎(chǔ):
1)為了克服傳統(tǒng)云存儲系統(tǒng)因中心化而存在對云服務(wù)提供者信任依賴等問題,本文所提網(wǎng)絡(luò)架構(gòu)中的節(jié)點地位對等.
2)網(wǎng)絡(luò)中的節(jié)點為穩(wěn)定節(jié)點,以適應(yīng)云存儲的需求;為了描述區(qū)間搜索技術(shù),本文對節(jié)點失效、會話異構(gòu)等問題不做討論.
3)本文以Pastry系統(tǒng)為基礎(chǔ)構(gòu)建網(wǎng)絡(luò),運用分布式哈希表來發(fā)布資源與定位,本文運用的哈希函數(shù)具有抗原像性、抗第二原像性以及強(qiáng)抗碰撞性等特征.
4)因考慮到目前流行的全同態(tài)算法存在加密速度慢,以及受搜索算法的搜索效率影響等問題,本文所提算法僅對資源屬性值進(jìn)行同態(tài)加密.
為準(zhǔn)確描述區(qū)間搜索模型及技術(shù),本文對所涉及的相關(guān)定義描述如下:
定義1:節(jié)點標(biāo)識,用以標(biāo)識對等云網(wǎng)絡(luò)中不同的節(jié)點,記為nodeId.
定義2:資源屬性值,能夠代表某資源相關(guān)特征的值,主要包括資源關(guān)鍵字、資源名以及所有者身份標(biāo)識等,記為VALUE;同態(tài)加密后的資源屬性值記為HFVALUE.
定義3:對象標(biāo)識,用以唯一標(biāo)識對等云網(wǎng)絡(luò)中存儲的資源對象,記為objId.
定義4:資源標(biāo)記,又稱為資源類型,具有相同類型的資源擁有相同的資源標(biāo)記,記為TYPE.
定義5:路由環(huán)節(jié)點信息表(RRNT,Routing Ring Node Table),用于構(gòu)建資源路由環(huán)的數(shù)據(jù)結(jié)構(gòu),其中包括下一個存儲同類型資源節(jié)點的節(jié)點標(biāo)識、對象標(biāo)識,具體定義如表1所示.
表1 路由環(huán)節(jié)點信息表
定義6:節(jié)點的資源信息表(SNT,Source Node Table),用于對等云節(jié)點存儲資源相關(guān)信息的數(shù)據(jù)結(jié)構(gòu),其中包括資源對象標(biāo)識、資源密文屬性值、資源標(biāo)記,具體定義如表2所示.
表2 節(jié)點的資源信息表
在結(jié)構(gòu)化的對等系統(tǒng)中,由于采用散列函數(shù)的散列屬性值來生成對象Id或節(jié)點Id,因此Id間沒有關(guān)聯(lián)性,僅適用于精確搜索.
為實現(xiàn)區(qū)間搜索,本對等云系統(tǒng)在Pastry系統(tǒng)的基礎(chǔ)上,首先采用同態(tài)加密算法GSW對屬性值進(jìn)行加密,并且以密文的形式計算出資源標(biāo)記;然后將相同資源標(biāo)記的節(jié)點鏈在一起形成路由環(huán)以便區(qū)間搜索. 具體舉例如下:現(xiàn)有相似資源(A,B,C,D),為保證其機(jī)密性,運用GSW算法計算出密文屬性(A′,B′,C′,D′),再通過哈希函數(shù)計算得到其對象objId為(126,359,87,98),并確定其資源標(biāo)記為S;然后,將這些資源及其資源標(biāo)記S發(fā)布到節(jié)點nodeId為(127,400,87,100)的節(jié)點上,并將這些節(jié)點構(gòu)造成一個路由環(huán),以便實現(xiàn)區(qū)間搜索,具體如圖2所示.
圖2 基于資源路由環(huán)的對等云區(qū)間搜索拓?fù)鋱D
圖2給出了基于資源路由環(huán)的對等云區(qū)間搜索拓?fù)鋱D,從圖中可以看出,相似屬性的資源被發(fā)布到nodeId沒有關(guān)聯(lián)性的節(jié)點上,因此,不適合進(jìn)行區(qū)間搜索. 為實現(xiàn)區(qū)間搜索,將存儲相似資源的節(jié)點存儲一個相同的資源標(biāo)記S,然后通過鏈接形成一個路由環(huán),本模型的具體構(gòu)建方法如下所示.
1)運用Pastry系統(tǒng)的網(wǎng)絡(luò)架構(gòu)方案來構(gòu)建對等網(wǎng)絡(luò).
2)結(jié)合同態(tài)加密算法計算出基于密文的資源標(biāo)記.
3)在資源發(fā)布時,依據(jù)資源標(biāo)記,將資源標(biāo)記相同的同類型資源采用鏈?zhǔn)江h(huán)的方法鏈接在一起,形成資源路由環(huán).
為實現(xiàn)在對等云中進(jìn)行區(qū)間搜索,資源應(yīng)依據(jù)基于資源路由環(huán)的對等云區(qū)間搜索拓?fù)淠P蛠磉M(jìn)行發(fā)布. 第一步,首先依據(jù)資源的屬性值VALUE按同態(tài)加密算法GSW計算出密文屬性FHVALUE,然后對密文運用同態(tài)算法計算出資源標(biāo)記,同種類型的資源擁有相同的資源標(biāo)記S. 這樣處理既確保屬性值的機(jī)密性,又便于鏈接相同類型的資源形成資源路由環(huán). 第二步,將資源密文屬性FHVALUE按SHA-1算法哈希出對象標(biāo)識objId;然后運用Pastry的路由算法PR發(fā)布路由消息,查找到與objId值相近的nodeId的網(wǎng)絡(luò)節(jié)點N,然后將資源、資源標(biāo)記以及資源其他信息發(fā)布到該節(jié)點上. 第三步,依據(jù)資源標(biāo)記值,在對等云系統(tǒng)中查找一個擁有相同資源標(biāo)記值的節(jié)點K;如果找到這樣的節(jié)點K,則把K的路由環(huán)節(jié)點信息表(RRNT,Routing Ring Node Table)中記載的節(jié)點M的路由信息發(fā)送給節(jié)點N;節(jié)點N據(jù)此信息生成自己的RRNT,并將自己的路由信息發(fā)送給節(jié)點K,節(jié)點K依此信息更新RRNT表,從而實現(xiàn)節(jié)點N加入資源路由環(huán). 如果在查找時,沒有找到擁有相同資源標(biāo)記的節(jié)點,說明該類型資源是第一次加入系統(tǒng),則將自己的路由信息放入RRNT中. 基于資源路由環(huán)的對等云資源發(fā)布算法(RPARRR,Resource Publishing Algorithm based on Resource Routing Ring)如下所示.
Function RPARRR (VALUE V)
1){/* 該算法用于對等云系統(tǒng)資源發(fā)布,輸入為資源屬性值V */
2)/* 運用同態(tài)加密算法GSW計算出密文屬性值FHV */
3)FHV=GSW(V);
4)/*調(diào)用密文計算函數(shù)getSouTy計算資源標(biāo)記S,并計算該類型數(shù)據(jù)區(qū)間最小值MIN與最大值MAX */
5)S=getSouTy(FHV);
6)/* 運用SHA-1算法計算出對象標(biāo)識objId */
7)objId=SHA-1(FHV);
8)/*調(diào)用Pastry的路由算法PR,查找到資源存儲節(jié)點N*/
9)N=PR(objId);
10)將資源發(fā)布到節(jié)點N中;
11)/*調(diào)用資源定位算法RLART,查找具有相似標(biāo)記S的資源節(jié)點*/
12)/* MIN至MAX為資源的屬性區(qū)間*/
13)K=RLART(S,MIN,MAX);
14)if(K!=NULL)
15){/* 如果查找到的節(jié)點K不為空*/
16)將K節(jié)點的路由環(huán)節(jié)點信息表RRNT中記載的路由信息發(fā)送給節(jié)點N;
17)節(jié)點N據(jù)此信息生成自己的RRNT;
18)將節(jié)點N的路由信息發(fā)送給節(jié)點K,節(jié)點K依據(jù)此信息更新其RRNT表;}
19)else{/*如果沒有找到這樣的節(jié)點,表示該節(jié)點是第一個節(jié)點*/
20)將節(jié)點N自己的路由信息存入RRNT;}
21)/*算法結(jié)束*/ }
在基于資源路由環(huán)的對等云資源發(fā)布算法中,我們可以在不改變原有對等云結(jié)構(gòu)的基礎(chǔ)上,將存儲相同類型資源的節(jié)點鏈接成一個資源路由環(huán). 完成資源路由環(huán)設(shè)計后,下面的任務(wù)就是如何在基于資源路由環(huán)的對等云系統(tǒng)中進(jìn)行資源的區(qū)間搜索.
在資源發(fā)布算法中,節(jié)點在插入到某資源路由環(huán)之前,需按資源類型定位到該資源路由環(huán). 因此,在給定一種資源類型后,如何在系統(tǒng)中查找到這種資源是本區(qū)間搜索技術(shù)的主要算法之一. 為實現(xiàn)該算法,本文提出了如下思想:由于本文所提的同類型資源定位算法采用基于密文搜索的機(jī)制,因此,若用戶已知資源類型為明文M,則在其明文區(qū)間[MMIN,MMAX]中隨機(jī)選擇一個值V,運用同態(tài)加密機(jī)制運算出其資源標(biāo)記S,及其屬性值區(qū)間[MIN,MAX]. 第一步,用戶在資源屬性值區(qū)間中運用隨機(jī)函數(shù)計算得到一個密文屬性值FHV,然后,依據(jù)SHA-1算法計算出該屬性值的對象標(biāo)識objId. 第二步,運用對等云系統(tǒng)的路由算法PR路由到節(jié)點K,查看K節(jié)點是否存在資源標(biāo)記為S的資源,如果存在,則查找結(jié)束并返回成功. 第三步,如果沒有找到,則重新在屬性區(qū)間中隨機(jī)產(chǎn)生一個新的密文屬性值FHV′,重新搜索. 第四步,直到搜索到此種類型的資源,返回成功算法結(jié)束;或者搜索次數(shù)超限返回失敗算法結(jié)束. 依據(jù)資源類型進(jìn)行資源定位的算法(RLART,Resource Location Algorithm based on Resource Type)如下所示.
Function RLART(TYPE S,F(xiàn)HVALUE MIN ,F(xiàn)HVALUE MAX)
1){/*該算法在給定資源類型標(biāo)記的情況下進(jìn)行資源定位,算法返回值為資源存儲所在節(jié)點的標(biāo)識*/
2)count=0;/*count變量用來記載搜索次數(shù),最大值為MaxCount */
3)flag=0;/* flag變量為是否搜索成功標(biāo)記,查找成功時,該值為1*/
4)while(count<=MaxCount)
5){/*在S類資源的屬性值區(qū)間內(nèi)隨機(jī)產(chǎn)生一個屬性值FHV */
6)FHV=random(S,MIN,MAX);
7)objId=SHA-1(FHV);/* 運用SHA-1算法計算出對象標(biāo)識objId */
8)/*調(diào)用Pastry的路由算法PR,將資源發(fā)布到路由到的節(jié)點K*/
9)K=PR(objId);
10)forEach(id in 節(jié)點K的SNT)
11){/* 遍歷K節(jié)點的資源信息表*/
12)if(id==objId)/* 如果查找的資源對象標(biāo)識找到 */
13){flag=1;
14)break;/*在查找成功時,中止循環(huán)*/}}
15)if(flag==1)break;
16)count++;/*計數(shù)器自加*/}
17)if(flag==0){/*沒有查找到對應(yīng)資源的節(jié)點時,返回空值*/
18)return NULL;}
19)else{/* 若找到對應(yīng)資源的節(jié)點時,返回節(jié)點的標(biāo)識 */
20)return K.nodeId;}
21)/*算法結(jié)束*/ }
該算法在不改變對等云覆蓋網(wǎng)絡(luò)結(jié)構(gòu)的基礎(chǔ)上構(gòu)建,具有較強(qiáng)的自適應(yīng)性,既支持密文資源定位,也支持明文資源定位;用戶在擁有明文的情況下進(jìn)行定位時,為確保操作過程的機(jī)密性,只需在調(diào)用該算法前進(jìn)行一次同態(tài)密碼運算即可完成.
在以資源路由環(huán)的方式發(fā)布資源后,在對等云系統(tǒng)中,擁有相同資源的節(jié)點通過存儲相同資源標(biāo)記的路由信息后,形成資源路由環(huán);本小節(jié)將描述在資源路由環(huán)中如何進(jìn)行區(qū)間搜索. 首先,當(dāng)用戶搜索關(guān)鍵字區(qū)間為[V1,V2] 時,若關(guān)鍵字為明文,則運用同態(tài)加密機(jī)制計算出密文區(qū)間[FHV1,F(xiàn)HV2],并計算出資源標(biāo)記S. 第二步,依據(jù)資源標(biāo)記值S,通過資源定位算法RLART搜索到存儲該類型資源的節(jié)點N. 第三步,以節(jié)點N為起始節(jié)點,在資源路由環(huán)中比對搜索區(qū)間關(guān)鍵字;若在此區(qū)間,則將存儲資源節(jié)點的節(jié)點標(biāo)識返回給用戶,直至遍歷資源路由環(huán)結(jié)束. 基于資源路由環(huán)的區(qū)間定位算法(ILARRR,Interval Location Algorithm based on Resource Routing Ring)如下所示.
Function ILARRR(FHVALUE FHV1,F(xiàn)HVALUE FHV2)
1){/*該算法實現(xiàn)在對等云系統(tǒng)中進(jìn)行區(qū)間搜索,區(qū)間為[FHV1,F(xiàn)HV2],F(xiàn)HVALUE為同態(tài)密文屬性類型*/
2)/*調(diào)用密文計算函數(shù)getSouTy計算出資源標(biāo)記S,并計算出該類型數(shù)據(jù)區(qū)間最值MIN與MAX */
3)S=getSouTy(FHV1);
4)/* 調(diào)用依據(jù)資源標(biāo)記定位資源算法RLART查找第一個存儲S類資源的節(jié)點N */
5)N=RLART(S,MIN,MAX);
6)if(N!=NULL){/*如N節(jié)點不為空,以N為第一個節(jié)點遍歷資源路由環(huán)*/
7)I=N;/*用臨時變量I存儲擁有S類資源的節(jié)點的路由信息*/
8)定義集合SourNode[]存儲資源節(jié)點的路由信息;
9)j=0;
10)do{
11)forEach(id in節(jié)點I的SNT)
12){/*遍歷I節(jié)點的資源信息表*/
13)if(id>=FHV1&&id<=FHV2)/* 如果查找的資源屬性值在搜索區(qū)間之內(nèi) */
14){SourNode[j].nodeId =I.nodeId;/*將I節(jié)點的路由信息存入資源節(jié)點集合SourNode*/
15)j++;
16)break;}}
17)I=I.RRNT.nodeId;/* 取出I節(jié)點的路由環(huán)節(jié)點信息表中的路由節(jié)點作為下一查找的節(jié)點 */
18)}while(I.nodeId !=N.nodeId);/* 循環(huán)到路由起點結(jié)束*/
19)}else return NULL;/*搜索失敗,返回空值*/
20)if(j>0){
21)/*搜索成功,返回資源節(jié)點集合*/
22)return SourNode;
23)}else{/*搜索失敗,返回空值*/
24)return NULL;}
25)/*算法結(jié)束*/}
上述算法的輸入為密文屬性區(qū)間,若用戶在已知明文區(qū)間的情況下進(jìn)行區(qū)間搜索,則需運用同態(tài)加密機(jī)制計算出密文區(qū)間,然后調(diào)用此算法來完成基于資源路由環(huán)的區(qū)間定位.
本文提出的區(qū)間搜索算法通過改進(jìn)Pastry對等系統(tǒng),運用資源路由環(huán)實現(xiàn)了密文資源區(qū)間的搜索,本搜索算法的路由開銷包括在Pastry網(wǎng)絡(luò)中的路由開銷以及在路由環(huán)中的路由開銷,現(xiàn)就其搜索效率分析如下:
2)找到資源路由環(huán)入口后,ILARRR算法運用遍歷環(huán)中資源節(jié)點的方法搜索資源,因此,其路由開銷與環(huán)的大小成正比;在資源規(guī)模較小的情況下,環(huán)內(nèi)路由開銷遠(yuǎn)遠(yuǎn)小于該算法調(diào)用RLART算法搜索環(huán)入口的路由開銷. 但若資源規(guī)模增大,環(huán)內(nèi)搜索勢必成為主要的搜索開銷之一,因此,為提高搜索效率,本文提出如下改進(jìn)措施:
① 在資源發(fā)布時,以資源屬性值為關(guān)鍵字來構(gòu)建有序鏈表的資源路由環(huán);
② 在資源定位時,運用資源路由環(huán)的有序性,優(yōu)化查找算法,以達(dá)到在資源路由環(huán)內(nèi)的搜索效率最優(yōu).
為了驗證運用結(jié)構(gòu)化對等系統(tǒng)Pastry作為對等云覆蓋網(wǎng)絡(luò)的有效性,我們選擇FreePastry為原型仿真器[15]來進(jìn)行仿真測試,網(wǎng)絡(luò)規(guī)模確定其最大值為10 000個網(wǎng)絡(luò)節(jié)點;節(jié)點標(biāo)識的構(gòu)成采用16進(jìn)制,N的大小為|N|=32,L的大小為|L|=16. 為了實現(xiàn)密文下的區(qū)間搜索,運用資源發(fā)布算法發(fā)布資源,設(shè)定算法RLART的最大搜索次數(shù)為10次,資源類型數(shù)量為200種;搜索區(qū)間的確定方法為從不同類型資源的屬性區(qū)間中隨機(jī)抽?。?實驗主要測試了網(wǎng)絡(luò)規(guī)模與路由開銷之間的關(guān)系,以及路由開銷與搜索區(qū)間長度之間的關(guān)系.
在測試網(wǎng)絡(luò)規(guī)模與路由開銷之間的關(guān)系時,從200種資源中隨機(jī)抽取資源,并確定搜索區(qū)間的長度為20個節(jié)點,網(wǎng)絡(luò)節(jié)點數(shù)量從1 000個增加至最大值10 000個,增值長度為500;最終在不同網(wǎng)絡(luò)規(guī)模下進(jìn)行了100次實驗,取其均值,獲得的平均路由開銷與網(wǎng)絡(luò)規(guī)模的關(guān)系如圖3所示.
圖3為網(wǎng)絡(luò)節(jié)點個數(shù)與平均路由跳數(shù)之間的關(guān)系,其中橫坐標(biāo)為網(wǎng)絡(luò)節(jié)點數(shù)(個),縱坐標(biāo)為平均路由開銷,單位為步跳數(shù)(hops). 從圖3可以看出,網(wǎng)絡(luò)規(guī)模從1 000增至10 000個節(jié)點的過程中,區(qū)間搜索的平均路由開銷的增長接近線性增長趨勢. 得到上述實驗結(jié)果的原因是:本文所提的對等云系統(tǒng)采用資源路由環(huán)進(jìn)行構(gòu)造,即將存儲同種類型資源的節(jié)點運用鏈接的方式形成一個資源環(huán),在路由查找過程中,主要開銷為基本覆蓋網(wǎng)絡(luò)的路由開銷,因此,平均路由開銷與網(wǎng)絡(luò)規(guī)模成正比關(guān)系.
圖3 平均路由開銷與網(wǎng)絡(luò)規(guī)模關(guān)系圖
區(qū)間搜索相比于精確搜索,其搜索的數(shù)據(jù)量大;常規(guī)情況下,搜索區(qū)間包含的節(jié)點個數(shù)越多,則路由開銷也會越大. 因此,搜索區(qū)間長度與路由開銷間的關(guān)系是區(qū)間搜索的重要評估指標(biāo). 在測試時,我們確定網(wǎng)絡(luò)規(guī)模為2 000個節(jié)點,搜索區(qū)間長度從10個節(jié)點增至100個節(jié)點,增值長度為10;從200種資源中隨機(jī)抽取資源,在不同的搜索區(qū)間長度下完成了100次實驗,取其平均路由開銷. 平均路由開銷與搜索區(qū)間長度之間的關(guān)系如圖4所示.
圖4 平均路由開銷與搜索區(qū)間長度關(guān)系圖
圖4為搜索區(qū)間長度與平均路由跳數(shù)之間的關(guān)系,橫坐標(biāo)為搜索區(qū)間長度,單位為搜索區(qū)間內(nèi)資源數(shù)量(個),縱坐標(biāo)為平均路由跳數(shù),單位為hops. 從圖中可以看出,隨著搜索區(qū)間的增大,其平均路由跳數(shù)的增長趨于平緩. 出現(xiàn)上述實驗結(jié)果的原因是:本系統(tǒng)運用資源路由環(huán)構(gòu)造,在路由過程中,主要開銷在于查找第一個資源,并且資源路由環(huán)中的路由開銷不大.
本文運用結(jié)構(gòu)化的對等系統(tǒng)來構(gòu)建云系統(tǒng)的覆蓋網(wǎng)絡(luò),采用將存儲相同類型資源的節(jié)點鏈接成資源路由環(huán),從而解決結(jié)構(gòu)化的對等云系統(tǒng)不適合區(qū)間搜索的問題. 另外,為確保數(shù)據(jù)的機(jī)密性,運用同態(tài)加密機(jī)制來實現(xiàn)密文下的資源搜索. 同態(tài)加密時間復(fù)雜性較大,本系統(tǒng)僅對資源屬性值進(jìn)行了同態(tài)加密. 下一步的工作將優(yōu)化同態(tài)加密算法,以使其在對等云系統(tǒng)中進(jìn)行密文運算時不受條件限制.