青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

面對(duì)現(xiàn)實(shí),超越自己
逆水行舟,不進(jìn)則退
posts - 269,comments - 32,trackbacks - 0
1、元數(shù)據(jù)(Metadata):維護(hù)HDFS文件系統(tǒng)中文件和目錄的信息,分為內(nèi)存元數(shù)據(jù)和元數(shù)據(jù)文件兩種。NameNode維護(hù)整個(gè)元數(shù)據(jù)。
HDFS實(shí)現(xiàn)時(shí),沒(méi)有采用定期導(dǎo)出元數(shù)據(jù)的方法,而是采用元數(shù)據(jù)鏡像文件(FSImage)+日子文件(edits)的備份機(jī)制。
2、Block:文件內(nèi)容而言。
尋路徑流程:
          路徑信息                         bocks[]                                   triplets[]          
Client ------------》INode---------------------》BlockInfo --------------------------》DataNode。
INode:文件的基本元素:文件和目錄
BlockInfo: 文件內(nèi)容對(duì)象
DatanodeDescriptor:具體存儲(chǔ)對(duì)象。
3 、 FSImage和edits的checkPoint。FSImage有2個(gè)狀態(tài),分別是FsImage和FsImage.ckpt,后者表示正在checkpoint的過(guò)程中,上傳后將會(huì)修改為FSImage文件,同理edits也有兩個(gè)狀態(tài),edits和edits.new。
4、NameNode format情景分析:
  • 遍歷元數(shù)據(jù)存儲(chǔ)目錄,提示用戶(hù)是否格式化?(NameNode.java里format函數(shù))
  1. private static boolean format( Configuration conf ,  
  2.                                 boolean isConfirmationNeeded )  
  3.       throws IOException {  
  4.     Collection<URI > dirsToFormat = FSNamesystem. getNamespaceDirs(conf );  
  5.     Collection<URI > editDirsToFormat =  
  6.                  FSNamesystem .getNamespaceEditsDirs (conf );  
  7.     for( Iterator< URI> it = dirsToFormat.iterator (); it. hasNext() ;) {  
  8.       File curDir = new File (it .next (). getPath()) ;  
  9.       if (! curDir. exists())  
  10.         continue;  
  11.       if (isConfirmationNeeded ) {  
  12.         System .err .print ("Re-format filesystem in " + curDir + " ? (Y or N) ");  
  13.         if (! (System .in .read () == 'Y')) {  
  14.           System .err .println ("Format aborted in " + curDir );  
  15.           return true ;  
  16.         }  
  17.         while(System .in .read () != '\n') ; // discard the enter-key  
  18.       }  
  19.     }  
  20.   
  21.     FSNamesystem nsys = new FSNamesystem (new FSImage(dirsToFormat ,  
  22.                                          editDirsToFormat ), conf) ;  
  23.     nsys.dir.fsImage .format ();  
  24.     return false;  
  25.   }  
  • 創(chuàng)建元數(shù)據(jù)內(nèi)存鏡像,包括類(lèi)FSNamesystem實(shí)例化對(duì)象,類(lèi)FSDirectory實(shí)例化對(duì)象,類(lèi)FSImage對(duì)象,類(lèi)Edits對(duì)象。創(chuàng)建FsNameSystem對(duì)象主要完成:BlockManager,F(xiàn)SDirectory對(duì)象以及初始化成員變量。FSImage對(duì)象主要完成對(duì)layoutVersion、namespaceID,CTime賦值為0,實(shí)例化FSEditLog。在類(lèi)FSDirectory,創(chuàng)建了HDFS根目錄節(jié)點(diǎn)rootDir。
  1. FSNamesystem( FSImage fsImage, Configuration conf ) throws IOException {  
  2.     this. blockManager = new BlockManager (this, conf) ;  
  3.     setConfigurationParameters (conf );  
  4.     this. dir = new FSDirectory(fsImage , this, conf );  
  5.     dtSecretManager = createDelegationTokenSecretManager (conf );  
  6.   }  
  7.   
  8.   FSImage( Collection< URI> fsDirs , Collection< URI> fsEditsDirs )  
  9.       throws IOException {  
  10.     this() ;  
  11.     setStorageDirectories( fsDirs, fsEditsDirs );  
  12.   }  
  13.   
  14.  void setStorageDirectories(Collection <URI > fsNameDirs,  
  15.                              Collection< URI> fsEditsDirs ) throws IOException {  
  16.     this. storageDirs = new ArrayList <StorageDirectory >() ;  
  17.     this. removedStorageDirs = new ArrayList <StorageDirectory >() ;  
  18.      
  19.    // Add all name dirs with appropriate NameNodeDirType  
  20.     for (URI dirName : fsNameDirs ) {  
  21.       checkSchemeConsistency (dirName );  
  22.       boolean isAlsoEdits = false;  
  23.       for (URI editsDirName : fsEditsDirs) {  
  24.         if (editsDirName .compareTo (dirName ) == 0) {  
  25.           isAlsoEdits = true;  
  26.           fsEditsDirs .remove (editsDirName );  
  27.           break;  
  28.         }  
  29.       }  
  30.       NameNodeDirType dirType = (isAlsoEdits ) ?  
  31.                           NameNodeDirType .IMAGE_AND_EDITS :  
  32.                           NameNodeDirType .IMAGE ;  
  33.       // Add to the list of storage directories, only if the  
  34.       // URI is of type file://  
  35.       if(dirName .getScheme (). compareTo( JournalType.FILE .name (). toLowerCase())  
  36.           == 0){  
  37.         this.addStorageDir (new StorageDirectory(new File(dirName. getPath()) ,  
  38.             dirType ));  
  39.       }  
  40.     }  
  41.      
  42.     // Add edits dirs if they are different from name dirs  
  43.     for (URI dirName : fsEditsDirs ) {  
  44.       checkSchemeConsistency (dirName );  
  45.       // Add to the list of storage directories, only if the  
  46.       // URI is of type file://  
  47.       if(dirName .getScheme (). compareTo( JournalType.FILE .name (). toLowerCase())  
  48.           == 0)  
  49.         this.addStorageDir (new StorageDirectory(new File(dirName. getPath()) ,  
  50.                     NameNodeDirType .EDITS ));  
  51.     }  
  52.   }  
  • 對(duì)內(nèi)存鏡像數(shù)據(jù)中的數(shù)據(jù)結(jié)構(gòu)進(jìn)行初始化:主要有FSImage的format函數(shù)完成,layoutVersion:軟件所處的版本。namespaceID:在Format時(shí)候產(chǎn)生,當(dāng)data node注冊(cè)到Name Node后,會(huì)獲得該NameNode的NameSpaceID,并作為后續(xù)與NameNode通訊的身份標(biāo)識(shí)。對(duì)于未知身份的Data Node,NameNode拒絕通信。CTime:表示FSimage產(chǎn)生的時(shí)間。checkpointTime:表示NameSpace第一次checkpoint的時(shí)間。  
  1. public void format () throws IOException {  
  2.    this. layoutVersion = FSConstants .LAYOUT_VERSION ;  
  3.    this. namespaceID = newNamespaceID ();  
  4.    this. cTime = 0L ;  
  5.    this. checkpointTime = FSNamesystem .now ();  
  6.    for (Iterator <StorageDirectory > it =  
  7.                           dirIterator (); it. hasNext() ;) {  
  8.      StorageDirectory sd = it .next ();  
  9.      format (sd );  
  10.    }  
  11.  }  
  • 對(duì)內(nèi)存鏡像寫(xiě)入元數(shù)據(jù)備份目錄。FSImage的format方法會(huì)遍歷所有的目錄進(jìn)行備份。如果是FSImage的文件目錄,則調(diào)用saveFSImage保存FSImage,如果是Edits,則調(diào)用editLog.createEditLogFile,最后調(diào)用sd.write方法創(chuàng)建fstime和VERSION文件。VERSION文件通常最后寫(xiě)入。
  1. void format(StorageDirectory sd ) throws IOException {  
  2.     sd.clearDirectory (); // create currrent dir  
  3.     sd.lock ();  
  4.     try {  
  5.       saveCurrent (sd );  
  6.     } finally {  
  7.       sd .unlock ();  
  8.     }  
  9.     LOG.info ("Storage directory " + sd. getRoot()  
  10.              + " has been successfully formatted.");  
  11.   }  
最后分析一下元數(shù)據(jù)應(yīng)用的場(chǎng)景:
1、格式化時(shí)。
2、Hadoop啟動(dòng)時(shí)。
3、元數(shù)據(jù)更新操作時(shí)。
4、如果NameNode與Secondary NameNode、Backup Node或checkpoint Node配合使用時(shí),會(huì)進(jìn)行checkPoint操作。

本文轉(zhuǎn)自:
http://blog.csdn.net/kntao/article/details/7769199
posted on 2013-05-24 15:18 王海光 閱讀(1042) 評(píng)論(0)  編輯 收藏 引用 所屬分類(lèi): Linux
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲免费成人av| 亚洲国产经典视频| 欧美精品在线一区| 久久精品72免费观看| 亚洲午夜在线| 亚洲日本电影| 你懂的成人av| 久久人人超碰| 欧美一区二区三区男人的天堂| 亚洲日本成人女熟在线观看| 国内精品久久久久影院 日本资源| 欧美午夜影院| 欧美人成在线视频| 免费视频一区| 乱人伦精品视频在线观看| 性8sex亚洲区入口| 亚洲一本视频| 亚洲图片欧美一区| 在线亚洲自拍| 99精品欧美一区二区蜜桃免费| 91久久夜色精品国产网站| 男女av一区三区二区色多| 久久久噜噜噜久久| 久久精品国产清高在天天线| 午夜亚洲福利| 欧美一区二区三区的| 亚洲欧美日韩精品久久久久| 亚洲一区三区视频在线观看 | 亚洲午夜久久久久久久久电影院| 亚洲福利在线看| 欧美激情1区2区3区| 免费中文日韩| 亚洲大片一区二区三区| 欧美激情精品久久久六区热门| 欧美成人一区二区三区| 欧美国产欧美亚州国产日韩mv天天看完整| 久久综合国产精品台湾中文娱乐网| 久久精品免费看| 久久黄金**| 久久综合色婷婷| 美女在线一区二区| 欧美好吊妞视频| 亚洲人被黑人高潮完整版| 亚洲精品免费在线| 日韩天堂在线视频| 亚洲无限av看| 欧美一区二区三区在线视频| 久久超碰97人人做人人爱| 久久久久久综合| 欧美电影免费观看网站| 欧美片第一页| 国产精品中文字幕欧美| 国产午夜精品视频免费不卡69堂| 国产亚洲一区精品| 亚洲国产成人在线播放| 日韩一级网站| 香蕉久久夜色精品国产使用方法| 久久精品一级爱片| 亚洲电影免费| 在线视频欧美精品| 久久久久久久综合| 欧美精品激情在线观看| 国产精品女人网站| 在线视频国内自拍亚洲视频| 宅男精品视频| 久久久久www| 亚洲欧洲一区二区三区久久| 亚洲视频高清| 久久综合999| 欧美视频在线一区| 国外成人在线视频网站| 99视频精品免费观看| 欧美一级在线视频| 亚洲电影中文字幕| 亚洲网站在线| 欧美成人激情在线| 国产欧美一区二区视频| 亚洲日本欧美天堂| 欧美在线观看视频在线| 亚洲欧洲一区二区天堂久久| 亚洲你懂的在线视频| 另类酷文…触手系列精品集v1小说| 欧美日韩免费高清| 极品少妇一区二区三区| 亚洲图色在线| 欧美11—12娇小xxxx| 亚洲综合电影| 欧美精品久久天天躁| 韩国成人精品a∨在线观看| 亚洲一区3d动漫同人无遮挡| 美国成人直播| 亚洲一区二区三区久久| 欧美第一黄色网| 狠狠久久婷婷| 欧美一区二区视频在线观看| 亚洲免费黄色| 嫩模写真一区二区三区三州| 国产中文一区| 香蕉久久久久久久av网站| 亚洲精品视频在线观看免费| 美国十次了思思久久精品导航| 国产日韩欧美综合一区| 亚洲午夜小视频| 91久久精品一区二区三区| 久久精品一二三区| 国产女人aaa级久久久级| 亚洲伊人一本大道中文字幕| 亚洲人成网站999久久久综合| 久久久成人精品| 国产一区二区三区高清| 欧美一区二区视频在线观看2020| 一区二区免费看| 欧美日韩一区在线视频| 一本大道av伊人久久综合| 欧美激情国产高清| 久久婷婷一区| 极品中文字幕一区| 久久综合影视| 久久久中精品2020中文| 国产在线视频欧美| 久久精品国产免费| 欧美亚洲一区三区| 国产欧美丝祙| 欧美伊人久久久久久久久影院| 中国成人亚色综合网站| 欧美视频在线观看免费网址| 亚洲午夜精品国产| 一本一本久久a久久精品综合麻豆| 欧美精品大片| 亚洲网站视频福利| 亚洲图片自拍偷拍| 国产精品一区二区三区乱码| 欧美一区二区三区四区在线观看| 亚洲一区免费观看| 国产嫩草一区二区三区在线观看| 校园激情久久| 欧美在线免费视频| 影音先锋国产精品| 欧美黄色一区二区| 欧美激情成人在线视频| 在线视频日韩| 亚洲午夜高清视频| 国产手机视频精品| 蜜臀va亚洲va欧美va天堂| 久久躁日日躁aaaaxxxx| 亚洲精品日韩在线观看| 亚洲日本视频| 国产精品外国| 久久综合久久久久88| 女人香蕉久久**毛片精品| 亚洲免费观看高清在线观看 | 国产精品日韩欧美大师| 久久成人综合网| 久久人人看视频| 亚洲精品欧美专区| 中文国产一区| 红桃视频成人| 亚洲全黄一级网站| 国产伦精品一区二区三区视频黑人| 久久久久www| 欧美经典一区二区| 欧美一区二区三区在线免费观看 | 国产精品劲爆视频| 久久久久久久综合日本| 欧美成人首页| 午夜视频在线观看一区| 久久午夜电影网| 亚洲一区二区精品| 久久久久久久久伊人| 亚洲视频一区二区免费在线观看| 亚洲欧美精品在线观看| 亚洲国产欧美一区二区三区丁香婷| 亚洲三级影院| 激情视频亚洲| 日韩一二三在线视频播| 韩日视频一区| aa级大片欧美三级| 伊人天天综合| 亚洲在线观看| 亚洲精品在线看| 久久精品论坛| 亚洲自拍电影| 欧美二区在线播放| 久久精品在线观看| 欧美日韩亚洲91| 欧美成人午夜| 国精品一区二区| 一本色道久久综合亚洲精品高清| 一区二区亚洲精品| 亚洲欧美日韩国产精品| 亚洲免费观看视频| 久久婷婷国产麻豆91天堂| 午夜激情亚洲| 欧美乱妇高清无乱码| 免费亚洲电影在线| 国产日产欧产精品推荐色 | 久久久久国色av免费看影院| 午夜精品福利在线| 欧美日韩三级| 亚洲国产岛国毛片在线|