簡單的介紹一下大數據中最重要的MapReduce

2021-02-06    分類: 網站建設

簡單的介紹一下大數據中最重要的MapReduce
MapReduce執行流程圖

概述

MapReduce是一種分布式計算模型,由Google提出,主要用于搜索領域,解決海量數據的計算問題。

MapReduce是分布式運行的,由兩個階段組成:Map和Reduce,Map階段是一個獨立的程序,有很多個節點同時運行,每個節點處理一部分數據。

Reduce階段是一個獨立的程序,有很多個節點同時運行,每個節點處理一部分數據。

使用

MapReduce框架都有默認實現,用戶只需要覆蓋map()和reduce()兩個函數,即可實現分布式計算,非常簡單。

這兩個函數的形參和返回值都是,使用的時候一定要注意構造。

簡單的介紹一下大數據中最重要的MapReduce

執行流程(此處舉例說明)

  1. 一個文本(在HDFS上面保存,兩個block)中每一個單詞的出現的次數: 
  2.     hello you hello marry 
  3.     hello me really 
  4.             ----->block-1 
  5.              
  6.     hello kate ready 
  7.     xiao wang hello tomcat 
  8.             ----->block-2 

1.獲取每一個block塊中的文本,遍歷所有,回去其中的一行str

因為要統計的是每一個單詞i的次數,所以還需要直到文本中有哪些單詞,可以根據字符串的特點,使用split()進行切割。

  1. String[] words=str.split(""); 

根據要求,需將每一個單詞i轉換為的形式,k為單詞本身,v為單詞出現的次數。

2.因為mr的計算是分布式的 ,每一個map(稱之為一個mapper task)計算其中的一個block塊數據。

  1. map階段: 
  2.     輸入<K1,V1> 
  3.         k1,偏移量,v1,當前行文本內容 
  4.         map()函數操作 
  5.     輸出<K2,V2> 
  6.         k2,具體單詞,v2,單詞對應的統計項,比如次數 
  7.     輸出<K2,V2> 
  1. shuffle階段 
  2. 研究后發現,如果按照<key,1>這種方式向reduce輸出數據的時候,會有 
  3. 大量的冗余數據。 
  4. 比如map階段之后有5個hello,則輸出<hello,1>,<hello,1>,<hello,1>, 
  5. <hello,1>,<hello,1>5次,實際上會對網絡造成一定的壓力,能不能對 
  6. 這5個<hello,1>進行一個進入reduce之前的本地組合?比如成為 
  7. <hello,5>或者<hello,[1,1,1,1,1]>. 
  8. 這個過程成為shuffle,洗牌重組階段,達到上述的結果,稱之為規約。 
  9. >>>shuffle階段,也就是對map的輸出進行重新洗牌: 
  10. 分區、分組、排序 
  11. <K2,V2>...===><K2,V2s> 
  1. reduce階段 
  2. 接收map的輸出結果<key,values> 
  3. 對這個結果進行匯總統計,針對values,進行簡單的累加,計算得出key 
  4. 對應的次數 
  5. reduce針對一個key調用一次reduce()函數 
  6. =====>reduce 階段 
  7. 輸入<K2,V2> 
  8.     K2,就是map的輸出的K2,V2s是map經過shuffle之后的結果集 
  9.     reduce()函數操作 
  10. 轉化為<K3,V3>   

經過上述操作之后,系統會將計算結果輸出給用戶,一般會先存儲(落地)到hdfs,然后反饋給用戶。

到此為止,MapReduce執行完畢,接下來就可以進行大數據的其他一系列操作了。

網頁名稱:簡單的介紹一下大數據中最重要的MapReduce
標題網址:http://m.kartarina.com/news39/99489.html

成都網站建設公司_創新互聯,為您提供App設計、靜態網站、電子商務、網站導航移動網站建設、企業網站制作

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

微信小程序開發
主站蜘蛛池模板: 亚洲精品无码不卡在线播放HE| 午夜无码A级毛片免费视频| 人妻无码αv中文字幕久久琪琪布 人妻无码第一区二区三区 | 无码人妻精品一区二区三区66| 久久久久久AV无码免费网站| 亚洲欧洲无码AV不卡在线| 潮喷无码正在播放| 亚洲AV无码AV吞精久久| 亚洲午夜国产精品无码老牛影视| 亚洲a∨无码一区二区| 亚洲国产精品无码久久久不卡| 国产精品无码久久四虎| 日韩精品无码一区二区三区免费 | 亚洲av永久无码精品三区在线4| 久久亚洲AV成人无码国产电影| 国产成人AV一区二区三区无码| 妖精色AV无码国产在线看| 无码精品人妻一区二区三区免费看| 日韩精品人妻系列无码av东京| 中文字幕日产无码| 无码少妇精品一区二区免费动态| 亚洲国产综合无码一区二区二三区 | 狠狠躁狠狠躁东京热无码专区| 无遮掩无码h成人av动漫| 人妻无码αv中文字幕久久琪琪布 人妻无码第一区二区三区 | 亚洲AV无码乱码在线观看裸奔| 亚洲AV蜜桃永久无码精品| 天堂一区人妻无码| 久久亚洲精品无码网站| 亚洲av午夜国产精品无码中文字| 永久免费无码网站在线观看个| 免费A级毛片无码免费视| av无码久久久久久不卡网站| 蜜桃成人无码区免费视频网站| 亚洲精品无码鲁网中文电影| 亚洲精品无码高潮喷水在线| 亚洲av中文无码乱人伦在线播放 | 亚洲AV永久无码精品一百度影院 | 国产精品午夜无码体验区 | 日韩精品无码久久一区二区三| 无码视频一区二区三区|