大數(shù)據(jù)培訓(xùn)講解_第1頁
大數(shù)據(jù)培訓(xùn)講解_第2頁
大數(shù)據(jù)培訓(xùn)講解_第3頁
大數(shù)據(jù)培訓(xùn)講解_第4頁
大數(shù)據(jù)培訓(xùn)講解_第5頁
已閱讀5頁,還剩115頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

大數(shù)據(jù)培訓(xùn)講解目錄大數(shù)據(jù)起源Hadoop1.0Hadoop2.0商用環(huán)境大數(shù)據(jù)起源-Google三篇GoogleMapReduceGoogle分布式文件系統(tǒng)GFSGoolge分布式構(gòu)造化數(shù)據(jù)表BigTable三個層面上的根本構(gòu)思如何對付大數(shù)據(jù)處理:分而治之 對相互間不具有計算依賴關(guān)系的大數(shù)據(jù),實現(xiàn)并行最自然的方法就是采取分而治之的策略上升到抽象模型:Mapper與Reducer MPI等并行計算方法缺少高層并行編程模型,為了抑制這一缺陷,MapReduce借鑒了Lisp函數(shù)式語言中的思想,用Map和Reduce兩個函數(shù)提供了高層的并行編程抽象模型上升到構(gòu)架:統(tǒng)一構(gòu)架,為程序員隱藏系統(tǒng)層細(xì)節(jié) MPI等并行計算方法缺少統(tǒng)一的計算框架支持,程序員需要考慮數(shù)據(jù)存儲、劃分、分發(fā)、結(jié)果收集、錯誤恢復(fù)等諸多細(xì)節(jié);為此,MapReduce設(shè)計并提供了統(tǒng)一的計算框架,為程序員隱藏了絕大多數(shù)系統(tǒng)層面的處理細(xì)節(jié)GoogleMapReduce的根本模型和處理思想GoogleMapReduce的根本模型和處理思想大數(shù)據(jù)分而治之

大數(shù)據(jù)計算任務(wù)子任務(wù)子任務(wù)子任務(wù)子任務(wù)……任務(wù)劃分計算結(jié)果結(jié)果合并建立Map和Reduce抽象模型典型的流式大數(shù)據(jù)問題的特征大量數(shù)據(jù)記錄/元素進(jìn)展重復(fù)處理對每個數(shù)據(jù)記錄/元素作感興趣的處理、獲取感興趣的中間結(jié)果信息排序和整理中間結(jié)果以利后續(xù)處理收集整理中間結(jié)果產(chǎn)生最終結(jié)果輸出MapReduce關(guān)鍵思想:為大數(shù)據(jù)處理過程中的兩個主要處理階段

提煉為一種抽象的操作機制GoogleMapReduce的根本模型和處理思想建立Map和Reduce抽象模型借鑒函數(shù)式程序設(shè)計語言Lisp中的思想,定義了Map和Reduce兩個抽象的操作函數(shù):map:(k1;v1)

[(k2;v2)]reduce:

(k2;[v2])

[(k3;v3)]特點:描述了對一組數(shù)據(jù)處理的兩個階段的抽象操作GoogleMapReduce的根本模型和處理思想上升到構(gòu)架--自動并行化并隱藏低層細(xì)節(jié)海量數(shù)據(jù)存儲……數(shù)據(jù)劃分MapMapMapMap初始kv鍵值對初始kv鍵值對初始kv鍵值對初始kv鍵值對中間結(jié)果(k1,val)(k2,val)(k3,val)(k1,val)(k3,val)(k2,val)(k3,val)(k1,val)(k2,val)(k3,val)Barrier:AggregationandShuffleReduceReduceReduce(k1,values)(k2,values)(k3,values)計算結(jié)果(K1,val)(K2,val)(K3,val)GoogleMapReduce的根本模型和處理思想Barrier(good,1)(good,1)(good,2)(good,1)PartitionerPartitionerPartitionerPartitioner(is,1)(is,1)(is,1)(has,1)(weather,1)(weather,1)(weather,1)(the,1)(today,1)(today,1)上升到構(gòu)架--自動并行化并隱藏低層細(xì)節(jié)海量數(shù)據(jù)存儲計算結(jié)果……數(shù)據(jù)劃分Map初始kv鍵值對初始kv鍵值對初始kv鍵值對初始kv鍵值對MapMapMap中間結(jié)果(the,1)(weather,1)(is,1)(good,1)CombinerCombinerCombinerCombiner(the,1)(weather,1)(is,1)(good,1)(today,1)(is,1)(good,1)(good,1)(weather,1)(is,1)(good,1)(today,1)(has,1)(good,1)(weather,1)(today,1)(is,1)(good,1)(good,2)(weather,1)(is,1)(today,1)(has,1)(good,1)(weather,1)ReduceReduceReduce(good,5)(is,3)(has,1)(weather,3)(the,1)(today,2)Combiner和PartitionerGoogleMapReduce的根本模型和處理思想GoogleMapReduce并行處理的根本過程

1.有一個待處理的大數(shù)據(jù),被劃分為大小一樣的數(shù)據(jù)塊(如64MB),及與此相應(yīng)的用戶作業(yè)程序2.系統(tǒng)中有一個負(fù)責(zé)調(diào)度的主節(jié)點(Master),以及數(shù)據(jù)Map和Reduce工作節(jié)點(Worker)GoogleMapReduce的根本模型和處理思想GoogleMapReduce并行處理的根本過程

3.用戶作業(yè)程序提交給主節(jié)點4.主節(jié)點為作業(yè)程序?qū)ふ液团鋫淇捎玫腗ap節(jié)點,并將程序傳送給map節(jié)點5.主節(jié)點也為作業(yè)程序?qū)ふ液团鋫淇捎玫腞educe節(jié)點,并將程序傳送給Reduce節(jié)點GoogleMapReduce的根本模型和處理思想GoogleMapReduce并行處理的根本過程

6.主節(jié)點啟動每個Map節(jié)點執(zhí)行程序,每個map節(jié)點盡可能讀取本地或本機架的數(shù)據(jù)進(jìn)展計算7.每個Map節(jié)點處理讀取的數(shù)據(jù)塊,并做一些數(shù)據(jù)整理工作(combining,sorting等)并將中間結(jié)果存放在本地;同時通知主節(jié)點計算任務(wù)完成并告知中間結(jié)果數(shù)據(jù)存儲位置GoogleMapReduce的根本模型和處理思想GoogleMapReduce并行處理的根本過程

8.主節(jié)點等所有Map節(jié)點計算完成后,開場啟動Reduce節(jié)點運行;Reduce節(jié)點從主節(jié)點所掌握的中間結(jié)果數(shù)據(jù)位置信息,遠(yuǎn)程讀取這些數(shù)據(jù)節(jié)點計算結(jié)果匯總輸出到一個結(jié)果文件即獲得整個處理結(jié)果GoogleMapReduce的根本模型和處理思想GoogleMapReduce并行處理的根本過程

完整計算過程GoogleMapReduce的根本模型和處理思想存儲位置的計算策略策略MapReduce的master在調(diào)度Map任務(wù)時會考慮輸入文件的位置信息,盡量將一個Map任務(wù)調(diào)度在包含相關(guān)輸入數(shù)據(jù)拷貝的機器上執(zhí)行;如果上述努力失敗了,master將嘗試在保存有輸入數(shù)據(jù)拷貝的機器附近的機器上執(zhí)行Map任務(wù)(例如,分配到一個和包含輸入數(shù)據(jù)的機器在一個switch里的worker機器上執(zhí)行)。當(dāng)在一個足夠大的cluster集群上運行大型MapReduce操作的時候,大局部的輸入數(shù)據(jù)都能從本地機器讀取,因此消耗非常少的網(wǎng)絡(luò)帶寬。。GoogleMapReduce的根本模型和處理思想失效處理主節(jié)點失效主節(jié)點中會周期性地設(shè)置檢查點(checkpoint),檢查整個計算作業(yè)的執(zhí)行情況,一旦某個任務(wù)失效,可以從最近有效的檢查點開場重新執(zhí)行,防止從頭開場計算的時間浪費。工作節(jié)點失效工作節(jié)點失效是很普遍發(fā)生的,主節(jié)點會周期性地給工作節(jié)點發(fā)送檢測命令,如果工作節(jié)點沒有回應(yīng),這認(rèn)為該工作節(jié)點失效,主節(jié)點將終止該工作節(jié)點的任務(wù)并把失效的任務(wù)重新調(diào)度到其它工作節(jié)點上重新執(zhí)行GoogleMapReduce的根本模型和處理思想CounterMapReduce庫使用計數(shù)器統(tǒng)計不同事件發(fā)生次數(shù)。比方,用戶可能想統(tǒng)計已經(jīng)處理了多少個單詞、已經(jīng)索引的多少篇文檔。這些計數(shù)器的值周期性的從各個單獨的worker機器上傳遞給master〔附加在ping的應(yīng)答包中傳遞〕。master把執(zhí)行成功的Map和Reduce任務(wù)的計數(shù)器值進(jìn)展累計,當(dāng)MapReduce操作完成之后,返回給用戶代碼GoogleMapReduce的根本模型和處理思想

帶寬優(yōu)化問題大量的鍵值對數(shù)據(jù)在傳送給Reduce節(jié)點時會引起較大的通信帶寬開銷。解決方案每個Map節(jié)點處理完成的中間鍵值隊將由combiner做一個合并壓縮,即把那些鍵名一樣的鍵值對歸并為一個鍵名下的一組數(shù)值。(good,1)(weather,1)(is,1)(good,1)(good,2)(weather,1)(is,1)combinerGoogleMapReduce的根本模型和處理思想

計算優(yōu)化問題Reduce節(jié)點必須要等到所有Map節(jié)點計算計算才能開場執(zhí)行,因此,如果有一個計算量大、或者由于某個問題導(dǎo)致很慢完畢的Map節(jié)點,那么會成為嚴(yán)重的“拖后腿者〞。解決方案把一個Map計算任務(wù)讓多個Map節(jié)點同時做,取最快完成者的計算結(jié)果。根據(jù)Google的測試,使用了這個冗余Map節(jié)點計算方法以后,計算任務(wù)性能提高40%多!GoogleMapReduce的根本模型和處理思想

用數(shù)據(jù)分區(qū)解決數(shù)據(jù)相關(guān)性問題問題一個Reduce節(jié)點上的計算數(shù)據(jù)可能會來自多個Map節(jié)點,因此,為了在進(jìn)入Reduce節(jié)點計算之前,需要把屬于一個Reduce節(jié)點的數(shù)據(jù)歸并到一起。解決方案在Map階段進(jìn)展了Combining以后,可以根據(jù)一定的策略對Map輸出的中間結(jié)果進(jìn)展分區(qū)(partitioning),這樣既可解決以上數(shù)據(jù)相關(guān)性問題防止Reduce計算過程中的數(shù)據(jù)通信。例如:有一個巨大的數(shù)組,其最終結(jié)果需要排序,每個Map節(jié)點數(shù)據(jù)處理好后,為了防止在每個Reduce節(jié)點本地排序完成后還需要進(jìn)展全局排序,我們可以使用一個分區(qū)策略如:(d%R),d為數(shù)據(jù)大小,R為Reduce節(jié)點的個數(shù),那么可根據(jù)數(shù)據(jù)的大小將其劃分到指定數(shù)據(jù)范圍的Reduce節(jié)點上,每個Reduce將本地數(shù)據(jù)拍好序后即為最終結(jié)果GoogleMapReduce的根本模型和處理思想目錄GoogleMapReduce的根本工作原理分布式文件系統(tǒng)GFS的根本工作原理分布式構(gòu)造化數(shù)據(jù)表BigTable根本問題海量數(shù)據(jù)怎么存儲?數(shù)據(jù)存儲可靠性怎么解決?當(dāng)前主流的分布文件系統(tǒng)有:RedHat的GFSIBM的GPFSSun的Lustre等主要用于對硬件設(shè)施要求很高的高性能計算或大型數(shù)據(jù)中心;價格昂貴且缺少完整的數(shù)據(jù)存儲容錯解決方案如Lustre只對元數(shù)據(jù)管理提供容錯處理,但對于具體的分布存儲節(jié)點,可靠性完全依賴于這些分布節(jié)點采用RAID或存儲區(qū)域網(wǎng)(SAN)技術(shù)提供容錯,一旦分布節(jié)點失效,數(shù)據(jù)就無法恢復(fù)。GoogleGFS文件系統(tǒng)GoogleGFS的根本設(shè)計原那么GoogleGFS是一個基于分布式集群的大型分布式文件系統(tǒng),為MapReduce計算框架提供低層數(shù)據(jù)存儲和數(shù)據(jù)可靠性支撐;GFS是一個構(gòu)建在分布節(jié)點本地文件系統(tǒng)之上的一個邏輯上文件系統(tǒng),它將數(shù)據(jù)存儲在物理上分布的每個節(jié)點上,但通過GFS將整個數(shù)據(jù)形成一個邏輯上整體的文件?!璆oogleGFSGoogleMapReduceMapReduceApplicationsGoogleGFS文件系統(tǒng)GoogleGFS的根本設(shè)計原那么廉價本地磁盤分布存儲各節(jié)點本地分布式存儲數(shù)據(jù),優(yōu)點是不需要采用價格較貴的集中式磁盤陣列,容量可隨節(jié)點數(shù)增加自動增加多數(shù)據(jù)自動備份解決可靠性采用廉價的普通磁盤,把磁盤數(shù)據(jù)出錯視為常態(tài),用自動多數(shù)據(jù)備份存儲解決數(shù)據(jù)存儲可靠性問題為上層的MapReduce計算框架提供支撐GFS作為向上層MapReduce執(zhí)行框架的底層數(shù)據(jù)存儲支撐,負(fù)責(zé)處理所有的數(shù)據(jù)自動存儲和容錯處理,因而上層框架不需要考慮低層的數(shù)據(jù)存儲和數(shù)據(jù)容錯問題GoogleGFS文件系統(tǒng)GoogleGFS的根本構(gòu)架和工作原理

CitefromGhemawatetal.(SOSP2003)GFSMasterChunkServerGoogleGFS文件系統(tǒng)GoogleGFS的工作原理GFSMasterMaster上保存了GFS文件系統(tǒng)的三種元數(shù)據(jù):命名空間(NameSpace),即整個分布式文件系統(tǒng)的目錄構(gòu)造Chunk與文件名的映射表Chunk副本的位置信息,每一個Chunk默認(rèn)有3個副本GFSMaster前兩種元數(shù)據(jù)可通過操作日志提供容錯處理能力;第3個元數(shù)據(jù)直接保存在ChunkServer上,Master啟動或ChunkServer注冊時自動完成在ChunkServer上元數(shù)據(jù)的生成;因此,當(dāng)Master失效時,只要ChunkServer數(shù)據(jù)保存完好,可迅速恢復(fù)Master上的元數(shù)據(jù)。GoogleGFS文件系統(tǒng)GoogleGFS的工作原理GFSChunkServer即用來保存大量實際數(shù)據(jù)的數(shù)據(jù)效勞器。GFS中每個數(shù)據(jù)塊劃分缺省為64MB每個數(shù)據(jù)塊會分別在3個(缺省情況下)不同的地方復(fù)制副本;對每一個數(shù)據(jù)塊,僅當(dāng)3個副本都更新成功時,才認(rèn)為數(shù)據(jù)保存成功。當(dāng)某個副本失效時,Master會自動將正確的副本數(shù)據(jù)進(jìn)展復(fù)制以保證足夠的副本數(shù)GFS上存儲的數(shù)據(jù)塊副本,在物理上以一個本地的Linux操作系統(tǒng)的文件形式存儲,每一個數(shù)據(jù)塊再劃分為64KB的子塊,每個子快有一個32位的校驗和,讀數(shù)據(jù)時會檢查校驗和以保證使用為失效的數(shù)據(jù)。ChunkServerGoogleGFS文件系統(tǒng)GoogleGFS的工作原理Chunk位置信息Master效勞器并不保存持久化保存哪個Chunk效勞器存有指定Chunk的副本的信息。Master效勞器只是在啟動的時候輪詢Chunk效勞器以獲取這些信息。Master效勞器能夠保證它持有的信息始終是最新的,因為它控制了所有的Chunk位置的分配,而且通過周期性的心跳信息監(jiān)控Chunk效勞器的狀態(tài)。ChunkServerGoogleGFS文件系統(tǒng)GoogleGFS的工作原理數(shù)據(jù)訪問工作過程1.在程序運行前,數(shù)據(jù)已經(jīng)存儲在GFS文件系統(tǒng)中;程序?qū)嵭袝r應(yīng)用程序會告訴GFSServer所要訪問的文件名或者數(shù)據(jù)塊索引是什么GoogleGFS文件系統(tǒng)GoogleGFS的工作原理數(shù)據(jù)訪問工作過程2.GFSServer根據(jù)文件名會數(shù)據(jù)塊索引在其文件目錄空間中查找和定位該文件或數(shù)據(jù)塊,并找數(shù)據(jù)塊在具體哪些ChunkServer上;將這些位置信息回送給應(yīng)用程序GoogleGFS文件系統(tǒng)GoogleGFS的工作原理數(shù)據(jù)訪問工作過程3.應(yīng)用程序根據(jù)GFSServer返回的具體Chunk數(shù)據(jù)塊位置信息,直接訪問相應(yīng)的ChunkServerGoogleGFS文件系統(tǒng)GoogleGFS的工作原理數(shù)據(jù)訪問工作過程GoogleGFS文件系統(tǒng)GoogleGFS的工作原理數(shù)據(jù)訪問工作過程特點:應(yīng)用程序訪問具體數(shù)據(jù)時部需要經(jīng)過GFSMaster,因此,防止了Master成為訪問瓶頸并發(fā)訪問:由于一個大數(shù)據(jù)會存儲在不同的ChunkServer中,應(yīng)用程序可實現(xiàn)并發(fā)訪問GoogleGFS文件系統(tǒng)GoogleGFS的工作原理GFS租約機制設(shè)計租約機制的目的是為了最小化Master節(jié)點的管理負(fù)擔(dān)。租約的初始超時設(shè)置為60秒。不過,只要Chunk被修改了,主Chunk就可以申請更長的租期,通常會得到Master節(jié)點確實認(rèn)并收到租約延長的時間。這些租約延長請求和批準(zhǔn)的信息通常都是附加在Master節(jié)點和Chunk效勞器之間的心跳消息中來傳遞。GoogleGFS文件系統(tǒng)GoogleGFS的工作原理數(shù)據(jù)流為了提高網(wǎng)絡(luò)效率,GFS采取了把數(shù)據(jù)流和控制流分開的措施。在控制流從客戶機到主Chunk、然后再到所有二級副本的同時,數(shù)據(jù)以管道的方式,順序的沿著一個精心選擇的Chunk效勞器鏈推送。我們的目標(biāo)是充分利用每臺機器的帶寬,防止網(wǎng)絡(luò)瓶頸和高延時的連接,最小化推送所有數(shù)據(jù)的延時。GoogleGFS文件系統(tǒng)GoogleGFS的工作原理數(shù)據(jù)完整性GFS把每個Chunk都分成64KB大小的塊。每個塊都對應(yīng)一個32位的Checksum。和其它元數(shù)據(jù)一樣,Checksum與其它的用戶數(shù)據(jù)是分開的,并且保存在內(nèi)存和硬盤上,同時也記錄操作日志。對于讀操作來說,在把數(shù)據(jù)返回給客戶端或者其它的Chunk效勞器之前,Chunk效勞器會校驗讀取操作涉及的范圍內(nèi)的塊的Checksum。因此Chunk效勞器不會把錯誤數(shù)據(jù)傳遞到其它的機器上。如果發(fā)生某個塊的Checksum不正確,Chunk效勞器返回給請求者一個錯誤信息,并且通知Master效勞器這個錯誤。作為回應(yīng),請求者應(yīng)當(dāng)從其它副本讀取數(shù)據(jù),Master效勞器也會從其它副本克隆數(shù)據(jù)進(jìn)展恢復(fù)。當(dāng)一個新的副本就緒后,Master效勞器通知副本錯誤的Chunk效勞器刪掉錯誤的副本。GoogleGFS文件系統(tǒng)GoogleGFS的工作原理Chunk副本的3種機制創(chuàng)立:當(dāng)Master節(jié)點創(chuàng)立一個Chunk時,它會選擇在哪里放置初始的空的副本。Master節(jié)點會考慮幾個因素?!?〕GFS希望在低于平均硬盤使用率的Chunk效勞器上存儲新的副本。這樣的做法最終能夠平衡Chunk效勞器之間的硬盤使用率?!?〕GFS希望限制在每個Chunk效勞器上〞最近〞的Chunk創(chuàng)立操作的次數(shù)。雖然創(chuàng)立操作本身是廉價的,但是創(chuàng)立操作也意味著隨之會有大量的寫入數(shù)據(jù)的操作,因為Chunk在Writer真正寫入數(shù)據(jù)的時候才被創(chuàng)立,而在我們的〞追加一次,讀取屢次〞的工作模式下,Chunk一旦寫入成功之后就會變?yōu)橹蛔x的了?!?〕GFS希望把Chunk的副本分布在多個機架之間。GoogleGFS文件系統(tǒng)GoogleGFS的工作原理Chunk副本的3種機制重新復(fù)制:當(dāng)Chunk的有效副本數(shù)量少于用戶指定的復(fù)制因數(shù)的時候,Master節(jié)點會重新復(fù)制它。這可能是由幾個原因引起的:一個Chunk效勞器不可用了,Chunk效勞器報告它所存儲的一個副本損壞了,Chunk效勞器的一個磁盤因為錯誤不可用了,或者Chunk副本的復(fù)制因數(shù)提高了。每個需要被重新復(fù)制的Chunk都會根據(jù)幾個因素進(jìn)展排序。一個因素是Chunk現(xiàn)有副本數(shù)量和復(fù)制因數(shù)相差多少。例如,喪失兩個副本的Chunk比喪失一個副本的Chunk有更高的優(yōu)先級。另外,GFS優(yōu)先重新復(fù)制活潑〔live〕文件的Chunk而不是最近剛被刪除的文件的Chunk。最后,為了最小化失效的Chunk對正在運行的應(yīng)用程序的影響,我們提高會阻塞客戶機程序處理流程的Chunk的優(yōu)先級。Master節(jié)點選擇優(yōu)先級最高的Chunk,然后命令某個Chunk效勞器直接從可用的副本〞克隆〞一個副本出來。選擇新副本的位置的策略和創(chuàng)立時類似:平衡硬盤使用率、限制同一臺Chunk效勞器上的正在進(jìn)展的克隆操作的數(shù)量、在機架間分布副本。為了防止克隆產(chǎn)生的網(wǎng)絡(luò)流量大大超過客戶機的流量,Master節(jié)點對整個集群和每個Chunk效勞器上的同時進(jìn)展的克隆操作的數(shù)量都進(jìn)展了限制。另外,Chunk效勞器通過調(diào)節(jié)它對源Chunk效勞器讀請求的頻率來限制它用于克隆操作的帶寬。GoogleGFS文件系統(tǒng)GoogleGFS的工作原理Chunk副本的3種機制重新負(fù)載均衡:最后,Master效勞器周期性地對副本進(jìn)展重新負(fù)載均衡:它檢查當(dāng)前的副本分布情況,然后移動副本以便更好的利用硬盤空間、更有效的進(jìn)展負(fù)載均衡。而且在這個過程中,Master效勞器逐漸的填滿一個新的Chunk效勞器,而不是在短時間內(nèi)用新的Chunk填滿它,以至于過載。新副本的存儲位置選擇策略和上面討論的一樣。另外,Master節(jié)點必須選擇哪個副本要被移走。通常情況,Master節(jié)點移走那些剩余空間低于平均值的Chunk效勞器上的副本,從而平衡系統(tǒng)整體的硬盤使用率。GoogleGFS文件系統(tǒng)GoogleGFS的工作原理過期失效的副本檢測當(dāng)Chunk效勞器失效時,Chunk的副本有可能因錯失了一些修改操作而過期失效。Master節(jié)點保存了每個Chunk的版本號,用來區(qū)分當(dāng)前的副本和過期副本。無論何時,只要Master節(jié)點和Chunk簽訂一個新的租約,它就增加Chunk的版本號,然后通知最新的副本。Master節(jié)點和這些副本都把新的版本號記錄在它們持久化存儲的狀態(tài)信息中。這個動作發(fā)生在任何客戶機得到通知以前,因此也是對這個Chunk開場寫之前。如果某個副本所在的Chunk效勞器正好處于失效狀態(tài),那么副本的版本號就不會被增加。Master節(jié)點在這個Chunk效勞器重新啟動,并且向Master節(jié)點報告它擁有的Chunk的集合以及相應(yīng)的版本號的時候,就會檢測出它包含過期的Chunk。如果Master節(jié)點看到一個比它記錄的版本號更高的版本號,Master節(jié)點會認(rèn)為它和Chunk效勞器簽訂租約的操作失敗了,因此會選擇更高的版本號作為當(dāng)前的版本號。Master節(jié)點在例行的垃圾回收過程中移除所有的過期失效副本。在此之前,Master節(jié)點在回復(fù)客戶機的Chunk信息請求的時候,簡單的認(rèn)為那些過期的塊根本就不存在。另外一重保障措施是,Master節(jié)點在通知客戶機哪個Chunk效勞器持有租約、或者指示Chunk效勞器從哪個Chunk效勞器進(jìn)展克隆時,消息中都附帶了Chunk的版本號??蛻魴C或者Chunk效勞器在執(zhí)行操作時都會驗證版本號以確??偸窃L問當(dāng)前版本的數(shù)據(jù)。GoogleGFS文件系統(tǒng)GoogleGFS的根本構(gòu)架和工作原理GFS的系統(tǒng)管理技術(shù)大規(guī)模集群安裝技術(shù):如何在一個成千上萬個節(jié)點的集群上迅速部署GFS,升級管理和維護(hù)等故障檢測技術(shù):GFS是構(gòu)建在不可靠的廉價計算機之上的文件系統(tǒng),節(jié)點數(shù)多,故障頻繁,如何快速檢測、定位、恢復(fù)或隔離故障節(jié)點節(jié)點動態(tài)參加技術(shù):當(dāng)新的節(jié)點參加時,需要能自動安裝和部署GFS節(jié)能技術(shù):效勞器的耗電本錢大于購置本錢,Google為每個節(jié)點效勞器配置了蓄電池替代UPS,大大節(jié)省了能耗。GoogleGFS文件系統(tǒng)目錄GoogleMapReduceGoogle分布式文件系統(tǒng)GFSGoogle分布式構(gòu)造化數(shù)據(jù)表BigTableBigTable的根本作用和設(shè)計思想GFS是一個文件系統(tǒng),難以提供對構(gòu)造化數(shù)據(jù)的存儲和訪問管理。為此,Google在GFS之上又設(shè)計了一個構(gòu)造化數(shù)據(jù)存儲和訪問管理系統(tǒng)—BigTable,為應(yīng)用程序提供比單純的文件系統(tǒng)更方便、更高層的數(shù)據(jù)操作能力Google的很多數(shù)據(jù),包括Web索引、衛(wèi)星圖像數(shù)據(jù)、地圖數(shù)據(jù)等都以構(gòu)造化形式存放在BigTable中BigTable提供了一定粒度的構(gòu)造化數(shù)據(jù)操作能力,主要解決一些大型媒體數(shù)據(jù)〔Web文檔、圖片等〕的構(gòu)造化存儲問題。但與傳統(tǒng)的關(guān)系數(shù)據(jù)庫相比,其構(gòu)造化粒度沒有那么高,也沒有事務(wù)處理等能力,因此,它并不是真正意義上的數(shù)據(jù)庫。GoogleBigTableBigTable設(shè)計動機和目標(biāo)主要動機需要存儲多種數(shù)據(jù) Google提供的效勞很多,序處理的數(shù)據(jù)類型也很多,如URL,網(wǎng)頁,圖片,地圖數(shù)據(jù),email,用戶的個性化設(shè)置等海量的效勞請求Google是目前世界上最繁忙的系統(tǒng),因此,需要有高性能的請求和數(shù)據(jù)處理能力商用數(shù)據(jù)庫無法適用在如此龐大的分布集群上難以有效部署商用數(shù)據(jù)庫系統(tǒng),且其難以承受如此巨量的數(shù)據(jù)存儲和操作需求GoogleBigTableBigTable設(shè)計動機和目標(biāo)主要設(shè)計目標(biāo)廣泛的適用性:為一系列效勞和應(yīng)用而設(shè)計的數(shù)據(jù)存儲系統(tǒng),可滿足對不同類型數(shù)據(jù)的存儲和操作需求很強的可擴展性:根據(jù)需要可隨時自動參加或撤銷效勞器節(jié)點高吞吐量數(shù)據(jù)訪問:提供P級數(shù)據(jù)存儲能力,每秒數(shù)百萬次的訪問請求高可用性和容錯性:保證系統(tǒng)在各種情況下度能正常運轉(zhuǎn),效勞不中斷自動管理能力:自動參加和撤銷效勞器,自動負(fù)載平衡簡單性:系統(tǒng)設(shè)計盡量簡單以減少復(fù)雜性和出錯率GoogleBigTableBigTable數(shù)據(jù)模型BigTable主要是一個分布式多維表,表中的數(shù)據(jù)通過:一個行關(guān)鍵字(rowkey)一個列關(guān)鍵字(columnkey)一個時間戳(timestamp)進(jìn)展索引和查詢定位的。BigTable對存儲在表中的數(shù)據(jù)不做任何解釋,一律視為字符串,具體數(shù)據(jù)構(gòu)造的實現(xiàn)有用戶自行定義。BigTable查詢模型(row:string,column:string,time:int64)結(jié)果數(shù)據(jù)字符串支持查詢、插入和刪除操作GoogleBigTableBigTable數(shù)據(jù)模型BigTable數(shù)據(jù)存儲格式行(Row):大小不超過64KB的任意字符串。表中的數(shù)據(jù)都是根據(jù)行關(guān)鍵字進(jìn)展排序的。n.www就是一個行關(guān)鍵字,指明一行存儲數(shù)據(jù)。URL地址倒排好處是:1)同一地址的網(wǎng)頁將被存儲在表中連續(xù)的位置,便于查找;2)倒排便于數(shù)據(jù)壓縮,可大幅提高數(shù)據(jù)壓縮率子表(Tablet):一個大表可能太大,不利于存儲管理,將在水平方向上被分為多個子表GoogleBigTableBigTable數(shù)據(jù)模型BigTable數(shù)據(jù)存儲格式列(Column):BigTable將列關(guān)鍵字組織成為“列族〞(columnfamily),每個族中的數(shù)據(jù)屬于同一類別,如anchor時一個列族,其下可有不同的表示一個個超鏈的列關(guān)鍵字。一個列族下的數(shù)據(jù)會被壓縮在一起存放。因此,一個列關(guān)鍵字可表示為:族名:列名(family:qualifier)content、anchor都是族名;而cnnsi和my.look.ca那么是anchor族中的列名。GoogleBigTableBigTable數(shù)據(jù)模型BigTable數(shù)據(jù)存儲格式時間戳(timestamp):很多時候同一個URL的網(wǎng)頁會不斷更新,而Google需要保存不同時間的網(wǎng)頁數(shù)據(jù),因此需要使用時間戳來加以區(qū)分。為了簡化不同版本的數(shù)據(jù)管理,BigTable提供給了兩種設(shè)置:保存最近的n個版本數(shù)據(jù)保存限定時間內(nèi)的所有不同版本數(shù)據(jù)GoogleBigTableBigTable根本構(gòu)架BigTable主效勞器BigTable客戶端BigTable客戶端程序庫BigTable子表效勞器BigTable子表效勞器BigTable子表效勞器BigTable子表效勞器……執(zhí)行元數(shù)據(jù)操作和負(fù)載平衡數(shù)據(jù)存儲和訪問操作數(shù)據(jù)存儲和訪問操作數(shù)據(jù)存儲和訪問操作數(shù)據(jù)存儲和訪問操作GFSChubby效勞器〔分布式鎖效勞〕GoogleWorkQueue負(fù)責(zé)故障監(jiān)控和處理子表數(shù)據(jù)的存儲及日志元數(shù)據(jù)存儲及主效勞器選擇GoogleBigTableBigTable根本構(gòu)架主效勞器新子表分配:當(dāng)一個新子表產(chǎn)生時,主效勞器通過加載命令將其分配給一個空間足夠大的子表效勞;創(chuàng)立新表、表合并及較大子表的分裂都會產(chǎn)生新的子表。子表監(jiān)控:通過Chubby完成。所有子表效勞器根本信息被保存在Chubby中的效勞器目錄中主效勞器檢測這個目錄可獲取最新子表效勞器的狀態(tài)信息。當(dāng)子表效勞器出現(xiàn)故障,主效勞器將終止該子表效勞器,并將其上的全部子表數(shù)據(jù)移動到其它子表效勞器。負(fù)債均衡:當(dāng)主效勞器發(fā)現(xiàn)某個子表效勞器負(fù)載過重時,將對自動對其進(jìn)展負(fù)載均衡操作。GoogleBigTableBigTable根本構(gòu)架子表效勞器BigTable中的數(shù)據(jù)都以子表形式保存在子表效勞器上,客戶端程序也直接和子表效勞器通信。分配:當(dāng)一個新子表產(chǎn)子表效勞器的主要問題包括子表的定位、分配、及子表數(shù)據(jù)的最終存儲。子表的根本存儲構(gòu)造SSTableSSTable是BigTable內(nèi)部的根本存儲構(gòu)造,以GFS文件形式存儲在GFS文件系統(tǒng)中。一個SSTable實際上對應(yīng)于GFS中的一個64MB的數(shù)據(jù)塊(Chunk)SSTable中的數(shù)據(jù)進(jìn)一步劃分為64KB的子塊,因此一個SSTable可以有多達(dá)1千個這樣的子塊。為了維護(hù)這些子塊的位置信息,需要使用一個Index索引。Index64Kblock64Kblock64KblockSSTableGoogleBigTableBigTable根本構(gòu)架子表效勞器子表數(shù)據(jù)格式概念上子表是整個大表的多行數(shù)據(jù)劃分后構(gòu)成。而一個子表效勞器上的子表將進(jìn)一步由很多個SSTAble構(gòu)成,每個SSTable構(gòu)成最終的在底層GFS中的存儲單位。Index64Kblock64Kblock64KblockSSTableIndex64Kblock64Kblock64KblockSSTableTabletStart:aardvarkEnd:appleGoogleBigTableBigTable根本構(gòu)架子表效勞器子表數(shù)據(jù)格式一個SSTable還可以為不同的子表所共享,以防止同樣數(shù)據(jù)的重復(fù)存儲。

SSTableSSTableSSTableSSTableTabletaardvarkappleTabletapple_two_EboatGoogleBigTableBigTable根本構(gòu)架子表效勞器子表尋址子表地址以3級B+樹形式進(jìn)展索引;首先從Chubby效勞器中取得根子表,由根子表找到二級索引指標(biāo),最后獲取最終的SSTable的位置

GoogleBigTableBigTable根本構(gòu)架子表效勞器MinorCompaction隨著寫操作的執(zhí)行,memtable的大小不斷增加。當(dāng)memtable的尺寸到達(dá)一個門限值的時候,這個memtable就會被凍結(jié),然后創(chuàng)立一個新的memtable;被凍結(jié)住memtable會被轉(zhuǎn)換成SSTable,然后寫入GFS。GoogleBigTableBigTable根本構(gòu)架子表效勞器MergingCompaction每一次MinorCompaction都會創(chuàng)立一個新的SSTable。通過定期在后臺執(zhí)行MergingCompaction過程合并文件,限制這類文件的數(shù)量。MergingCompaction過程讀取一些SSTable和memtable的內(nèi)容,合并成一個新的SSTable。MajorCompactionMajorCompaction過程生成的SSTable不包含已經(jīng)刪除的信息或數(shù)據(jù)。Bigtable循環(huán)掃描它所有的Tablet,并且定期對它們執(zhí)行MajorCompaction。MajorCompaction機制允許Bigtable回收已經(jīng)刪除的數(shù)據(jù)占有的資源,并且確保BigTable能及時去除已經(jīng)刪除的數(shù)據(jù)。GoogleBigTableBigTable根本構(gòu)架優(yōu)化壓縮每個SSTable的塊〔塊的大小由局部性群組的優(yōu)化參數(shù)定〕都使用用戶指定的壓縮格式來壓縮。雖然分塊壓縮浪費了少量空間〔相比于對整個SSTable進(jìn)展壓縮,分塊壓縮壓縮率較低〕,但是,在只讀取SSTable的一小局部數(shù)據(jù)的時候就不必解壓整個文件了。使用了“兩遍〞的、可定制的壓縮方式。第一遍采用BentleyandMcIlroy’s方式,這種方式在一個很大的掃描窗口里對常見的長字符串進(jìn)展壓縮;第二遍是采用快速壓縮算法,即在一個16KB的小掃描窗口中尋找重復(fù)數(shù)據(jù)。兩個壓縮的算法都很快,在現(xiàn)在的機器上,壓縮的速率到達(dá)100-200MB/s,解壓的速率到達(dá)400-1000MB/s。GoogleBigTableBigTable根本構(gòu)架優(yōu)化Bloomfilter一個讀操作必須讀取構(gòu)成Tablet狀態(tài)的所有SSTable的數(shù)據(jù)。如果這些SSTable不在內(nèi)存中,那么就需要屢次訪問硬盤。我們通過允許客戶程序?qū)μ囟ň植啃匀航M的SSTable指定Bloom過濾器,來減少硬盤訪問的次數(shù)。我們可以使用Bloom過濾器查詢一個SSTable是否包含了特定行和列的數(shù)據(jù)。對于某些特定應(yīng)用程序,我們只付出了少量的、用于存儲Bloom過濾器的內(nèi)存的代價,就換來了讀操作顯著減少的磁盤訪問的次數(shù)。使用Bloom過濾器也隱式的到達(dá)了當(dāng)應(yīng)用程序訪問不存在的行或列時,大多數(shù)時候我們都不需要訪問硬盤的目的。GoogleBigTableBigTable根本構(gòu)架Bloomfilter原理如需要判斷一個元素是不是在一個集合中,我們通常做法是把所有元素保存下來,然后通過比較知道它是不是在集合內(nèi),鏈表、樹都是基于這種思路,當(dāng)集合內(nèi)元素個數(shù)的變大,我們需要的空間和時間都線性變大,檢索速度也越來越慢。Bloomfilter采用的是哈希函數(shù)的方法,將一個元素映射到一個m長度的陣列上的一個點,當(dāng)這個點是1時,那么這個元素在集合內(nèi),反之那么不在集合內(nèi)。這個方法的缺點就是當(dāng)檢測的元素很多的時候可能有沖突,解決方法就是使用k個哈希函數(shù)對應(yīng)k個點,如果所有點都是1的話,那么元素在集合內(nèi),如果有0的話,元素那么不在集合內(nèi)。初始狀態(tài)時,BloomFilter是一個包含m位的位數(shù)組,每一位都置為0。GoogleBigTableBigTable根本構(gòu)架Bloomfilter為了表達(dá)S={x1,x2,…,xn}這樣一個n個元素的集合,BloomFilter使用k個相互獨立的哈希函數(shù)〔HashFunction〕,它們分別將集合中的每個元素映射到{1,…,m}的范圍中。對任意一個元素x,第i個哈希函數(shù)映射的位置hi(x)就會被置為1〔1≤i≤k〕。注意,如果一個位置屢次被置為1,那么只有第一次會起作用,后面幾次將沒有任何效果。在以下圖中,k=3,且有兩個哈希函數(shù)選中同一個位置〔從左邊數(shù)第五位〕。在判斷y是否屬于這個集合時,我們對y應(yīng)用k次哈希函數(shù),如果所有hi(y)的位置都是1〔1≤i≤k〕,那么我們就認(rèn)為y是集合中的元素,否那么就認(rèn)為y不是集合中的元素。以下圖中y1就不是集合中的元素。y2或者屬于這個集合,或者剛好是一個falsepositive。GoogleBigTable目錄大數(shù)據(jù)起源Hadoop1.0Hadoop2.0商用環(huán)境hadoopHadoop是一個開源的軟件框架,它支持?jǐn)?shù)據(jù)密集型的分布式應(yīng)用,許可授權(quán)隸屬于Apachev2license.可以在成千上萬臺獨立的計算機上運行。Hadoop源自于Google的MapReduce和GoogleFileSystem(GFS)兩篇論文?,F(xiàn)在通常認(rèn)為完整的ApacheHadoop‘平臺’由Hadoop內(nèi)核、MapReduce和HDFS組成,以及假設(shè)干相關(guān)的工程——包括ApacheHive、ApacheHbase等等Hadoop介紹

HDFS根本構(gòu)架對等于GFS

Master對等于GFS

ChunkServer應(yīng)用程序HDFS客戶端文件名或數(shù)據(jù)塊號數(shù)據(jù)塊號,數(shù)據(jù)塊位置HDFSNameNodeDataNode數(shù)據(jù)DataNode數(shù)據(jù)DataNode數(shù)據(jù)Hadoop的分布式文件系統(tǒng)HDFSHadoopMapReduce根本構(gòu)架與工作過程2.HadoopMapReduce的根本工作原理對等于GoogleMapReduce中的Master對等于GoogleMapReduce中的WorkerdatanodedaemonLinuxfilesystem…tasktrackerslavenodedatanodedaemonLinuxfilesystem…tasktrackerslavenodedatanodedaemonLinuxfilesystem…tasktrackerslavenodenamenodenamenodedaemonjobsubmissionnodejobtrackerHadoop介紹

HadoopMapReduce和HDFS數(shù)據(jù)存儲與計算節(jié)點構(gòu)架X86PC集群本機硬盤本機硬盤本機硬盤本機硬盤本機硬盤本機硬盤數(shù)據(jù)節(jié)點Datanode數(shù)據(jù)節(jié)點Datanode數(shù)據(jù)節(jié)點Datanode數(shù)據(jù)節(jié)點Datanode數(shù)據(jù)節(jié)點Datanode管理節(jié)點Datanode備份管理節(jié)點Datanode萬兆交換萬兆交換數(shù)據(jù)查詢〔Hbase〕運算與處理〔Map-Reduce)數(shù)據(jù)提取〔HIVE〕ETLOozieTaskTracker(MapTask)TaskTracker(MapTask)中間結(jié)果中間結(jié)果TaskTracker(ReduceTask)輸出數(shù)據(jù)JobTracker任務(wù)調(diào)度任務(wù)調(diào)度狀態(tài)監(jiān)控狀態(tài)監(jiān)控任務(wù)管理調(diào)度管理Hadoop處理層-設(shè)備及拓?fù)涮幚韺?軟件技術(shù)架構(gòu)SQL-Script列式存儲Hive架構(gòu)轉(zhuǎn)化為Map-Reduce程序列式索引Hadoop1.0架構(gòu)下的混搭處理中心X86PC集群本機硬盤本機硬盤本機硬盤本機硬盤本機硬盤本機硬盤數(shù)據(jù)節(jié)點Datanode數(shù)據(jù)節(jié)點Datanode數(shù)據(jù)節(jié)點Datanode數(shù)據(jù)節(jié)點Datanode數(shù)據(jù)節(jié)點Datanode管理節(jié)點Namenode備份管理節(jié)點Namenode萬兆交換萬兆交換數(shù)據(jù)查詢〔Hbase〕運算與處理〔Map-Reduce)數(shù)據(jù)提取〔HIVE〕ETL數(shù)據(jù)存儲:磁盤陣列數(shù)據(jù)計算:

數(shù)據(jù)效勞器HadoopRDB&內(nèi)存庫RDB內(nèi)存數(shù)據(jù)庫處理層-設(shè)備及拓?fù)涮幚韺?軟件技術(shù)架構(gòu)。主ID,億級查詢,毫秒級。次級索引查詢,秒級。外部提供noSql查詢方式。使用CoprocessorMR程序,滿足臨時性分析。。億級數(shù)據(jù),支持秒級查詢。支持SQL方式提取數(shù)據(jù)。支持?jǐn)?shù)據(jù)匯總,數(shù)據(jù)提取的快速開發(fā)。通過MR開發(fā),滿足絕大局部數(shù)據(jù)處理需求。支持十億級,百億級的數(shù)據(jù)分析與開發(fā)。結(jié)合Mahout,滿足對大數(shù)據(jù)的分析需求。通過結(jié)合文本處理技術(shù),滿足非構(gòu)造化文本數(shù)據(jù)需求。OLTP及數(shù)據(jù)量較小的OLAP管理節(jié)點備份保證平安數(shù)據(jù)冗余參數(shù)設(shè)置,保障根底數(shù)據(jù)平安實時數(shù)據(jù)查詢〔Impala〕。Jdbc/ODBC列式存儲HRegion-Server混搭架構(gòu)解決各類數(shù)據(jù)訪問需求根底存儲〔HDFS〕滿足萬分之一秒訪問并行查詢調(diào)度查詢優(yōu)化器本機硬盤本機硬盤MPP萬兆交換ODSLinux:FSDW&DMDB-File。Jdbc/ODBC。支持SQL方式提取數(shù)據(jù)。支持關(guān)聯(lián)性查詢。對內(nèi)存有效利用。對網(wǎng)絡(luò)帶寬有依賴Hbase&HiveHBase原理復(fù)雜查詢和二級索引HBase與Hive集成HBase簡介HBase是分布式的、面向列的開源數(shù)據(jù)庫HBase是GoogleBigtable的開源實現(xiàn)底層基于Hadoop,HDFS為HBase提供高可靠性的底層存儲支持,MapReduce為HBase提供高性能的計算能力Zookeeper為HBase提供了穩(wěn)定效勞和failover機制HBase簡介HBase中有兩張?zhí)厥獾腡able,-ROOT-和.META..META.:記錄了用戶表的Region信息,.META.可以有多個regoin-ROOT-:記錄了.META.表的Region信息,-ROOT-只有一個region?Zookeeper中記錄了-ROOT-表的locationClient訪問用戶數(shù)據(jù)之前需要首先訪問zookeeper,然后訪問-ROOT-表,接著訪問.META.表,最后才能找到用戶數(shù)據(jù)的位置去訪問,中間需要屢次網(wǎng)絡(luò)操作,不過client端會做cache緩存。ZookeeperQuorum中除了存儲了-ROOT-表的地址和HMaster的地址,HRegionServer也會把自己以Ephemeral方式注冊到Zookeeper中,使得HMaster可以隨時感知到各個HRegionServer的安康狀態(tài)。HMaster沒有單點問題,HBase中可以啟動多個HMaster,通過Zookeeper的MasterElection機制保證總有一個Master運行當(dāng)HRegionServer意外終止后,HMaster會通過Zookeeper感知到HBase數(shù)據(jù)模型RowKeycontentsanchorCMy.look.caTimestampvalueTimestampvalueTimestampvalueCn.wwwt3<html>…t8CNNt9CNN.comt5<html>…t6<html>…RowKey:table主鍵,HBase中記錄按照RowKey排序Timestamp:時間戳,HBase可以保存多版本的數(shù)據(jù)ColumnFamily,列簇,HBase中的集中存儲單元ColumnQualifier,與ColumnFamily一起標(biāo)記某一列HFile構(gòu)造名稱字節(jié)數(shù)說明keyLength4表示Key所占的總字節(jié)數(shù)valueLength4表示Value所占的總字節(jié)數(shù)rowLength2表示rowKey所占的字節(jié)數(shù)rowrowLength數(shù)據(jù)的rowKeycolumnFamilyLength1表示列族名稱所占的字節(jié)數(shù)columnFamilycolumnFamilyLength列族名稱columnQualifier

列名與columnFamily一起標(biāo)記唯一列timestamp8時間戳type1Key類型,比如是新增(Put),還是刪除(Delete)valuevalueLength列值KeyValue構(gòu)造說明Hfile構(gòu)造:KeyValue構(gòu)造:列存儲RowKey基本信息成績名字性別語文數(shù)學(xué)TimestampvalueTimestampvalueTimestampvalueTimestampvalue小明keyt1小明t2男t580t990t483t893t385t795文件1文件21724小明key4成績語文t5180HBase系統(tǒng)架構(gòu)Client通過zookeeper與master通信進(jìn)行管理類操作client與regionserver通信進(jìn)行數(shù)據(jù)讀寫操作存儲-ROOT-表地址存儲HMaster的地址協(xié)調(diào)多個HMaster防止單點問題管理用戶對表的操作調(diào)整Region分布,負(fù)載均衡管理Regionsplit后的region重分布RegionServer宕機后region的遷移工作響應(yīng)用戶的I/O請求,向HDFS中讀寫文件HBase數(shù)據(jù)訪問流程clientzookeeper關(guān)鍵文件:/hbase/hbaseid集群ID,跟存儲在HDFS上的hbase.id文件中的一致/hbase/master服務(wù)器名稱/hbase/root-region-server持有-ROOT-表regions的regionserver的服務(wù)器名稱-ROOT-表記錄.META.的Region信息,該region永遠(yuǎn)不split,只會有一個Region。表數(shù)據(jù)結(jié)構(gòu):rowkey:

存儲.META.的region的名稱columnFamily:共一個,為“info”columnQualifier共三個包含:regioninfo:保存region的信息,包括name、startkey、 endkey等信息server:該region所在RegionServerserverstartcord:region所在RegionServer啟動時間RowKeyinforegioninfoserverserverstartcord.META.,,1NAME=>'.META.,,1',STARTKEY=>'',ENDKEY=>'',ENCODED=>1028785192,}cloud204:600201371430827702UserTable,100,1371430844857.de0b50NAME=>UserTable,100,1371430844857.de0b50',STARTKEY=>‘100',ENDKEY=>‘200',ENCODED=>de0b50,}cloud199:600201371430844857.META.表記錄用戶表的Region信息:表數(shù)據(jù)結(jié)構(gòu)與-ROOT-相似:rowkey:

存儲用戶表的region的名稱columnFamily:共一個,為“info”columnQualifier共三個包含:regioninfo:保存region的信息,包括name、startkey、 endkey等信息server:該region所在RegionServerserverstartcord:region所在RegionServer啟動時間HRegionServer構(gòu)造每個HRegion對應(yīng)Table中的Region,由多個HStore組成HBase中的集中的存儲單元,對應(yīng)Table中的ColumnFamily,由MemStore和StoreFile組成HRegionServer:包含多個HRegionHRegionServer構(gòu)造Region合并和分割HStore存儲是HBase存儲的核心了,其中由兩局部組成,一局部是MemStore,一局部是StoreFiles。1.MemStore是SortedMemoryBuffer,用戶寫入的數(shù)據(jù)首先會放入MemStore,當(dāng)MemStore滿了以后會Flush成一個StoreFile〔底層實現(xiàn)是HFile〕.2.當(dāng)StoreFile文件數(shù)量增長到一定閾值,會觸發(fā)Compact合并操作,將多個StoreFiles合并成一個StoreFile,合并過程中會進(jìn)展版本合并和數(shù)據(jù)刪除,因此可以看出HBase其實只有增加數(shù)據(jù),所有的更新和刪除操作都是在后續(xù)的compact過程中進(jìn)展的,這使得用戶的寫操作只要進(jìn)入內(nèi)存中就可以立即返回,保證了HBaseI/O的高性能。3.當(dāng)StoreFilesCompact后,會逐步形成越來越大的StoreFile,當(dāng)單個StoreFile大小超過一定閾值后,會觸發(fā)Split操作,同時把當(dāng)前RegionSplit成2個Region,父Region會下線,新Split出的2個孩子Region會被HMaster分配到相應(yīng)的HRegionServer上,使得原先1個Region的壓力得以分流到2個Region上。HStore中數(shù)據(jù)寫入流程PUTFlushCompactSplitClient端PUT數(shù)據(jù)數(shù)據(jù)寫入MemStore中MemStore寫滿后執(zhí)行flush數(shù)據(jù)被flush為StoreFileStoreFile數(shù)量增長到閥值,觸發(fā)Compact操作多個StoreFile合并成一個StoreFile版本合并,數(shù)據(jù)刪除Region大小到達(dá)閥值,執(zhí)行Split操作一個Region會Split成成兩個Master上線新的兩個Region舊的Region下線HBaseCoprocessorHBaseCoprocessor實現(xiàn)目的:HBase0.92版本新增加特性,為了解決如下問題HBase無法輕易建立“二級索引〞執(zhí)行求和、計數(shù)、排序等操作比較困難,必須通過mapreduce實現(xiàn),對于簡單的統(tǒng)計或聚合計算時,可能會因為網(wǎng)絡(luò)開銷大而帶來性能問題靈感來源:靈感來源于bigtable的協(xié)處理器,包含如下特性每個表效勞器的任意子表都可以運行代碼客戶端能夠直接訪問數(shù)據(jù)表的行,多行讀寫會自動分片成多個并行的RPC調(diào)用提供接口:RegionObserver:提供客戶端的數(shù)據(jù)操縱事件鉤子:Get、Put、Delete、Scan等WALObserver:提供WAL相關(guān)操作鉤子MasterObserver:提供DDL-類型的操作鉤子。如創(chuàng)立、刪除、修改數(shù)據(jù)表等Endpoint:終端是動態(tài)RPC插件的接口,它的實現(xiàn)代碼被安裝在效勞器端,能夠通過HBaseRPC調(diào)用喚醒應(yīng)用范圍:通過使用RegionObserver接口可以實現(xiàn)二級索引的創(chuàng)立和維護(hù)通過使用Endpoint接口,在對數(shù)據(jù)進(jìn)展簡單排序和sum,count等統(tǒng)計操作時,能夠極大提高性能RegionObserver工作原理RegionObserver提供客戶端的數(shù)據(jù)操縱事件鉤子,Get、Put、Delete、Scan,使用此功能能夠解決主表以及多個索引表之間數(shù)據(jù)一致性的問題CoprocessorEndpoint2.客戶端通過調(diào)用count方法查詢,等待查詢結(jié)果1.操作region上數(shù)據(jù)的代碼,需要先安裝到效勞器端,客戶端通過接口調(diào)用3.HBase通過RPC喚醒安裝在效勞器端的實現(xiàn)代碼〔CountProtocol〕,等待執(zhí)行結(jié)果返回,然后通過callback回調(diào)會聚函數(shù)4.會聚每個region上的返回數(shù)據(jù),更新最終結(jié)果5.返回最終查詢結(jié)果目錄HBase原理復(fù)雜查詢和二級索引HBase與Hive集成HBase二級索引HBase二級索引HBase索引需求:HBase只支持針對與主鍵key的高性能查詢HBase本身不支持快速的復(fù)雜查詢和join索引的實現(xiàn)目標(biāo):高性能的數(shù)據(jù)檢索數(shù)據(jù)的低冗余數(shù)據(jù)的一致性索引的實現(xiàn)方式:基于表的索引,多個索引時每個索引建一個表或者建組合索引基于列的索引,所有索引存單張表,每個索引字段為一個列簇第三方工具框架:ITHbase,HBase索引的事務(wù)行解決方案,版本以后的HBase已經(jīng)可以通過Coprocessor實現(xiàn)其功能Lily,基于HBase和SOLR實現(xiàn),能夠提供快速的檢索和模糊查詢表索引實現(xiàn)原理發(fā)揮HBase基于主鍵查詢效率高的特點,添加索引表,把基于索引字段的查詢轉(zhuǎn)換為基于HBase主鍵的查詢業(yè)務(wù)表key101101…………key102102…………key103103…………

基于column1字段的查詢先查Index表Index表101key101102key102103key103rowkeycolumn1column2……表索引的使用和維護(hù)索引表的維護(hù)索引表的使用

CoprocessorUserTableIndexTablePut/DeletepostPut/postDeleteRegionServer通過開發(fā)基于Coprocessor的RegionObserver接口的程序?qū)崿F(xiàn)對索引表的維護(hù)

CoprocessorUserTableIndexTableScanCoprocessorHMasterperScan判斷查詢是否走索引

通過索引獲取原表數(shù)據(jù)

不走索引,直接scantable通過Coprocessor的perScan判斷是否是scan索引字段如果走索引,通過IndexTable查到UserTable的key,再去UserTable中查詢ValueHBase組合索引支持更靈活的查詢,對每個索引都可以進(jìn)展范圍查詢和等于匹配key……key……key……業(yè)務(wù)表MsisdnIndex表TimeIndex表CellIndex表key……key……key……業(yè)務(wù)表msisdn+cell+timekey組合索引表數(shù)據(jù)冗余較多數(shù)據(jù)一致性維護(hù)更復(fù)雜、數(shù)據(jù)導(dǎo)入速度更慢查詢是需要做多個表的查詢以及數(shù)據(jù)合并,會影響查詢效率數(shù)據(jù)的冗余較少查詢效率更高數(shù)據(jù)一致性維護(hù)較容易只支持索引最后一個字段的范圍查詢,其他索引字段只能等于匹配組合索引多個索引表HBase列索引將ColumnFamily做為index,多個index值散落到Qualifier,多個column值依據(jù)version排列查詢時,先找到該table索引所在位置,再選擇使用哪一個索引,再根據(jù)該索引字段的值查出主表的rowkeyrowkeycolumn1column2101102103你好再見tableAkey101key102key103key101key103key102tableB……tableC……tableAkey101101……key102102……key103103……rowkeycolumn1column2……你好你好再見

索引表的columnFamily值為column1,表示是針對column1的索引

該條數(shù)據(jù)的rowkey為tableA,表示是針對tableA的索引column2列數(shù)據(jù)的值為“你好〞的有多條數(shù)據(jù),用HBase的多個版本號標(biāo)識表索引和列索引比較列索引表索引檢索性能需要三次scan只需要一次scan存儲空間在沒有組合索引時,存儲較節(jié)省在沒有組合索引時,存儲較節(jié)省事務(wù)容易比較困難,需要使用Coprocessor來保證Join性能較差,只有在建立組合條件Qualifier的時候性能會有所改善性能較差,只有在建立組合表索引的時候性能會有所改善統(tǒng)計符合條件的結(jié)果集全表掃描符合條件的結(jié)果集全表掃描其他問題同一個row里每個qualifier的version是有大小限制的,version的count總數(shù)需要額外做處理獲取,單個row數(shù)據(jù)超過split大小時,會導(dǎo)致不能compaction或compactionLily簡介Lily是一個HBase和SOLR實現(xiàn)的數(shù)據(jù)倉庫提供強大的搜索能力,包括全表檢索和模糊查詢?yōu)槿乃饕峁┓?wù),LilyNode插入內(nèi)容會同步輸出到SOLRNode,SOLR自己生成全文索引存儲HBase的數(shù)據(jù),直接供Client使用通過HBase存儲Client寫入的數(shù)據(jù)每個LilyNode用Zookeeper來發(fā)布自己的存在,Client可以從Zookeeper獲取當(dāng)前有多少個LilyNode在提供服務(wù)LilyNode架構(gòu)Repository:這個是Client操作的入口,Client使用基于Avro的協(xié)議操作Repository,在Repository中操作HBase、添加SecondaryIndex信息。WAL:保證Index信息和原始信息的最終一致性。MessageQueue:實現(xiàn)任務(wù)的異步完成,用HBase里面的一個Table來實現(xiàn)。Indexer:Indexer的主要功能是同步SOLR,進(jìn)而實現(xiàn)全文索引。LinkIndex:根據(jù)Index來查找具體類容的模塊,Repository和Indexer都會用到。目錄HBase原理復(fù)雜查詢和二級索引HBase與Hive集成HBase與Hive整合原理使用hive和hbase對外的接口可以實現(xiàn)它們之間的整合Hive+HBase的導(dǎo)入和查詢數(shù)據(jù)導(dǎo)入數(shù)據(jù)查詢導(dǎo)入數(shù)據(jù)時通過HBase端put進(jìn)展通過hive外部表的方式創(chuàng)立表,存儲方式指定為HBaseStorageHandlerHBase整合Hive后,即可以通過Hive的Sql進(jìn)展查詢,也可以通過HBase的API進(jìn)展Scan和get查詢HDFSHBASEHiveputHFilehive-hbase-handler

HDFSHBASEHivescan/getHFilehive-hbase-handler

HivesqlHive與Hive+HBase比較HiveHive+HBaseHBase數(shù)據(jù)存儲Hive基于HDFS存儲基于HBase的HFile基于HFile數(shù)據(jù)導(dǎo)入1.內(nèi)部表通過load或insert兩種方式導(dǎo)入2.外部表直接添加HDFS到hive的鏈接1.內(nèi)部表需要先load進(jìn)hive,再insert到HBase2.外部表先put進(jìn)HBase,再添加到hive的鏈接調(diào)用put接口或者通過MapReduce生成HFile導(dǎo)入性能外部表只添加鏈接,快內(nèi)部表需要對數(shù)據(jù)進(jìn)行處理,稍慢內(nèi)部表需要先導(dǎo)入hive再insert進(jìn)HBase,慢外部表put進(jìn)HBase,稍快比hive導(dǎo)入慢查詢性能HiveSQL會轉(zhuǎn)換為MapReduce執(zhí)行,比原生MapReduce稍慢比hive直接從HDFS查詢慢基于key的查詢很快復(fù)雜查詢走M(jìn)apReduce查詢實現(xiàn)Hive提供了sql,實現(xiàn)查詢方便通過Hive提供了sql,實現(xiàn)方便必須通過API接口通過程序?qū)崿F(xiàn)查詢目錄大數(shù)據(jù)起源Hadoop1.0Hadoop2.0商用環(huán)境目前的大數(shù)據(jù)技術(shù)架構(gòu):ClouderaManagerCluustermanager&monitoringMahoutMachineLearningHiveBatchqueryHBaseNosqlkvstoreImpalaRealTimequeryOozieWorkflowtoolsMapReduceDataprocessingHDFSDataStorageSqoopImport&ExportofRelationaldatabaseFlumeImport&ExportofDataflowsZookeeperClustercoodination目前的大數(shù)據(jù)架構(gòu)目前的大數(shù)據(jù)技術(shù)架構(gòu)的缺乏:缺少真正意義上的流式場景的計算模型,目前都通過降低oozie定時調(diào)度的時長,而且hadoop是批處理技術(shù)模型,處理流式場景的應(yīng)用,效率很低。在數(shù)據(jù)挖掘場景上,mahout雖然支持很多數(shù)據(jù)挖掘算法,但大多數(shù)數(shù)據(jù)挖掘算法都迭代計算的,mahout是基于mapreduce的,每次迭代都要將結(jié)果存儲在hdfs中,所以在處理速度上還是可以提升的。目前大數(shù)據(jù)技術(shù)是基于hadoop1.X之上構(gòu)建,hadoop是非常優(yōu)秀批處理技術(shù)模型,與其他計算模型整合很難,比方:流式計算模型Storm。需要一種能整合多種計算模型的架構(gòu),來統(tǒng)一調(diào)度集群的資源,如:cpu、內(nèi)存。目前hive和impala版本有些低了,新版本hive和impala性能和穩(wěn)定性提升不少。目前的大數(shù)據(jù)架構(gòu)hadoop1.0到:Hadoop1.0MapReduce(clusterresourcemanagement&dataprocessing)HDFS(redundant,reliablestorage)Hadoop2.0HDFSFederationYARN(clusterresourcemanagement)MapReduce(dataprocessing)Others(dataprocessing)Hadoop2.0兩個最大改進(jìn):1.集群資源調(diào)用框架YARN,已經(jīng)集成多種計算模型。2.HDFSFederation架構(gòu)提升hdfs擴展性,解決了namenode的單點問題。新技術(shù)的引入—整合多種計算模型YARN:YARN管理多種計算模型HDFSFederationYARNBatchMapReduceStreamingStormIn-MemorySparkOnlineHbaseOtherTezYarn可以管理多種大數(shù)據(jù)計算模型,比方:流式計算和hadoop的批處理計算可以在cluster內(nèi)共同執(zhí)行。新技術(shù)的引入—整合多種計算模型YARN軟件架構(gòu):ResourceManagerNodeManagerAM1NodeManagerNodeManagerNodeManagerNodeManagerNodeManagerNodeManagerNodeManagerContainer1.1Container2.3AM2Container1.2Container2.1Container2.2Scheduler新技術(shù)的引入—整合多種計算模型YARN資源調(diào)度:Resourc

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論