寫這篇文章的原因是給那些看了很多干貨,但是覺(jué)得說(shuō)的太多,對(duì)于剛?cè)腴T的同學(xué)看起來(lái)是比較枯燥的事情,那么筆者就對(duì)此總結(jié)了hadoop簡(jiǎn)潔版。希望能夠幫助初學(xué)的小伙伴。分享之前我還是要推薦下我自己創(chuàng)建的大數(shù)據(jù)學(xué)習(xí)交流Qun: 710219868 進(jìn)Qun聊邀請(qǐng)碼填寫 南風(fēng)(必填)我就知道是你了
沙坡頭網(wǎng)站建設(shè)公司成都創(chuàng)新互聯(lián)公司,沙坡頭網(wǎng)站設(shè)計(jì)制作,有大型網(wǎng)站制作公司豐富經(jīng)驗(yàn)。已為沙坡頭成百上千提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\成都外貿(mào)網(wǎng)站建設(shè)要多少錢,請(qǐng)找那個(gè)售后服務(wù)好的沙坡頭做網(wǎng)站的公司定做!
Hadoop可以說(shuō)是大數(shù)據(jù)儲(chǔ)存和計(jì)算的開(kāi)山鼻祖了,現(xiàn)在大多數(shù)的開(kāi)源框架都依賴于Hadoop,或者能與它更好的兼容。
Hadoop的由來(lái):
Hadoop是一個(gè)由Apache基金會(huì)所開(kāi)發(fā)的分布式系統(tǒng)基礎(chǔ)架構(gòu)。
Hadoop實(shí)現(xiàn)了一個(gè)分布式文件系統(tǒng)(Hadoop Distributed File System),簡(jiǎn)稱HDFS。HDFS有高容錯(cuò)性的特點(diǎn),并且設(shè)計(jì)用來(lái)部署在低廉的(low-cost)硬件上;而且它提供高吞吐量(high throughput)來(lái)訪問(wèn)應(yīng)用程序的數(shù)據(jù),適合那些有著超大數(shù)據(jù)集(large data set)的應(yīng)用程序。HDFS放寬了(relax)POSIX的要求,可以以流的形式訪問(wèn)(streaming access)文件系統(tǒng)中的數(shù)據(jù)。
hadoop的核心總共有兩個(gè):HDFS(為海量數(shù)據(jù)提供儲(chǔ)存)、MapReduce(為海量數(shù)據(jù)提供了計(jì)算)
hadoop的優(yōu)點(diǎn): 是一個(gè)能對(duì)大數(shù)據(jù)進(jìn)行分布式處理的軟件框架、是一種可靠、高效、高伸縮的方式進(jìn)行處理數(shù)據(jù).
哪里可靠:因?yàn)樗僭O(shè)了計(jì)算元素或儲(chǔ)存失敗,因此它維護(hù)了多個(gè)工作數(shù)據(jù)和副本,確保能夠針對(duì)失敗的節(jié)點(diǎn)進(jìn)行重新分布處理
哪里高效:因?yàn)樗且圆⑿械姆绞竭M(jìn)行工作,通過(guò)并行處理加快處理速度
還是可伸縮的,因?yàn)榭梢蕴幚鞵B級(jí)數(shù)據(jù)
那么說(shuō)了這么多干貨,究竟hadoop是干嘛的。具體能做什么呢
hadoop就是適用于大數(shù)據(jù)存儲(chǔ)和大數(shù)據(jù)分析的應(yīng)用,適用于幾千臺(tái)或者幾萬(wàn)臺(tái)服務(wù)器的集群運(yùn)行,支持PB級(jí)的存儲(chǔ)容量。
hadoop提供了什么功能呢?
利用服務(wù)器集群,根據(jù)用戶自定義的業(yè)務(wù)邏輯對(duì)海量數(shù)據(jù)進(jìn)行分布式處理!
hadoop運(yùn)用于什么場(chǎng)景呢?
目前最典型是運(yùn)用于對(duì) 數(shù)據(jù)量特別大、數(shù)據(jù)類型復(fù)雜,無(wú)法用傳統(tǒng)數(shù)據(jù)庫(kù)進(jìn)行儲(chǔ)存和處理的的文本、日志、視頻、圖片、地理位置等.
技術(shù)介紹:
HDFS:
那么顧名思義大數(shù)據(jù)首先是要把數(shù)據(jù)儲(chǔ)存下來(lái)。而HDFS的設(shè)計(jì)本質(zhì)就是為了大量數(shù)據(jù)能夠橫跨成千上萬(wàn)個(gè)服務(wù)器存儲(chǔ)。
比如說(shuō)你獲取了/hdfs/tmp/a1的數(shù)據(jù),雖然你看到的只是一個(gè)路徑的數(shù)據(jù),但是很可能這個(gè)數(shù)據(jù)存儲(chǔ)在很多不同的機(jī)器上。
作為用戶根本不關(guān)注你這些數(shù)據(jù)儲(chǔ)存在了哪里和儲(chǔ)存在多少個(gè)地方,更多關(guān)注數(shù)據(jù)的使用和處理,這些就要交給HDFS管理。
MapReduce:
那么我們能夠存儲(chǔ)數(shù)據(jù)了,就要考慮如何處理數(shù)據(jù)了,一臺(tái)計(jì)算機(jī)處理T或者P以上的數(shù)據(jù)可能需要好幾天,這種效率明顯公司是不能接受的,但是我們?nèi)绻褂煤芏嗯_(tái)計(jì)算機(jī)處理的話就面臨了計(jì)算機(jī)之間如何分配的任務(wù),如何通信、數(shù)據(jù)交換。這就是MapReduce/Spack要處理的問(wèn)題了。提供了可靠的能在集群上運(yùn)行的計(jì)算模型。
Hive:
簡(jiǎn)單來(lái)說(shuō)就是程序員在寫MapReduce程序的時(shí)候發(fā)現(xiàn)很麻煩,但是可以通過(guò)Hive解決這個(gè)事情。
hive是通過(guò)SQL的方式自動(dòng)把腳本或者SQL翻譯成MapReduce程序,然后丟給計(jì)算引擎去處理
因?yàn)镾QL比較容易上手,容易修改,可能一兩行的SQL語(yǔ)句換成MapReduce可能幾十行,幾百行
上面介紹的就是數(shù)據(jù)倉(cāng)庫(kù)的基本架構(gòu)了,底層是 HDFS,上面運(yùn)行的是 MapReduce/Spark,在往上封裝的是Hive。
Storm:
想要更快的計(jì)算處理速度!Storm 是最流行的流計(jì)算平臺(tái)。流處理的思路就是在數(shù)據(jù)進(jìn)入系統(tǒng)的時(shí)候就進(jìn)行處理,基本無(wú)延遲。缺點(diǎn)是不靈活,必須事先直到需要統(tǒng)計(jì)的數(shù)據(jù),數(shù)據(jù)流過(guò)就沒(méi)有了,沒(méi)法進(jìn)行補(bǔ)算。因此它是個(gè)好東西,但還是無(wú)法代替上述體系的。
HBase:
HBase 是一個(gè)構(gòu)建與 HDFS 的分布式,面向列的存儲(chǔ)系統(tǒng)。以 key value 對(duì)的方式存儲(chǔ)數(shù)據(jù)并對(duì)存取操作做了優(yōu)化,能夠飛快的根據(jù) key 獲取綁定的數(shù)據(jù)。例如從幾個(gè) P 的數(shù)據(jù)中找×××號(hào)只需要零點(diǎn)幾秒。