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

面對現(xiàn)實,超越自己
逆水行舟,不進則退
posts - 269,comments - 32,trackbacks - 0
1、元數(shù)據(jù)(Metadata):維護HDFS文件系統(tǒng)中文件和目錄的信息,分為內(nèi)存元數(shù)據(jù)和元數(shù)據(jù)文件兩種。NameNode維護整個元數(shù)據(jù)。
HDFS實現(xiàn)時,沒有采用定期導出元數(shù)據(jù)的方法,而是采用元數(shù)據(jù)鏡像文件(FSImage)+日子文件(edits)的備份機制。
2、Block:文件內(nèi)容而言。
尋路徑流程:
          路徑信息                         bocks[]                                   triplets[]          
Client ------------》INode---------------------》BlockInfo --------------------------》DataNode。
INode:文件的基本元素:文件和目錄
BlockInfo: 文件內(nèi)容對象
DatanodeDescriptor:具體存儲對象。
3 、 FSImage和edits的checkPoint。FSImage有2個狀態(tài),分別是FsImage和FsImage.ckpt,后者表示正在checkpoint的過程中,上傳后將會修改為FSImage文件,同理edits也有兩個狀態(tài),edits和edits.new。
4、NameNode format情景分析:
  • 遍歷元數(shù)據(jù)存儲目錄,提示用戶是否格式化?(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)存鏡像,包括類FSNamesystem實例化對象,類FSDirectory實例化對象,類FSImage對象,類Edits對象。創(chuàng)建FsNameSystem對象主要完成:BlockManager,F(xiàn)SDirectory對象以及初始化成員變量。FSImage對象主要完成對layoutVersion、namespaceID,CTime賦值為0,實例化FSEditLog。在類FSDirectory,創(chuàng)建了HDFS根目錄節(jié)點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.   }  
  • 對內(nèi)存鏡像數(shù)據(jù)中的數(shù)據(jù)結(jié)構(gòu)進行初始化:主要有FSImage的format函數(shù)完成,layoutVersion:軟件所處的版本。namespaceID:在Format時候產(chǎn)生,當data node注冊到Name Node后,會獲得該NameNode的NameSpaceID,并作為后續(xù)與NameNode通訊的身份標識。對于未知身份的Data Node,NameNode拒絕通信。CTime:表示FSimage產(chǎn)生的時間。checkpointTime:表示NameSpace第一次checkpoint的時間。  
  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.  }  
  • 對內(nèi)存鏡像寫入元數(shù)據(jù)備份目錄。FSImage的format方法會遍歷所有的目錄進行備份。如果是FSImage的文件目錄,則調(diào)用saveFSImage保存FSImage,如果是Edits,則調(diào)用editLog.createEditLogFile,最后調(diào)用sd.write方法創(chuàng)建fstime和VERSION文件。VERSION文件通常最后寫入。
  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ù)應用的場景:
1、格式化時。
2、Hadoop啟動時。
3、元數(shù)據(jù)更新操作時。
4、如果NameNode與Secondary NameNode、Backup Node或checkpoint Node配合使用時,會進行checkPoint操作。

本文轉(zhuǎn)自:
http://blog.csdn.net/kntao/article/details/7769199
posted on 2013-05-24 15:18 王海光 閱讀(1035) 評論(0)  編輯 收藏 引用 所屬分類: 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>
            久久精品国产久精国产爱| 久久久久网址| 欧美精品一区三区在线观看| 宅男噜噜噜66一区二区| 久久精品免费电影| 夜夜嗨av一区二区三区中文字幕 | 国产视频在线观看一区二区| 亚洲激情网站| 久久伊伊香蕉| 午夜视频一区在线观看| 国产精品免费一区豆花| 亚洲免费一区二区| 中日韩美女免费视频网站在线观看| 欧美凹凸一区二区三区视频| 亚洲国产成人在线| 亚洲国产精品成人一区二区| 午夜精品久久| 国产日韩在线视频| 久久www免费人成看片高清| 亚洲欧美一区在线| 国产一区观看| 美女精品自拍一二三四| 久久一区二区三区国产精品| 在线播放不卡| 亚洲高清电影| 欧美日韩免费精品| 亚洲午夜免费视频| 亚洲婷婷国产精品电影人久久| 欧美成人精品一区| 性刺激综合网| 欧美激情精品久久久久久免费印度| 香蕉成人伊视频在线观看| 中文亚洲欧美| 在线观看日韩专区| 日韩一级在线观看| 一色屋精品亚洲香蕉网站| 亚洲人成人一区二区三区| 国产嫩草一区二区三区在线观看| 欧美无砖砖区免费| 国产精品一二| 免费中文日韩| 欧美日韩免费网站| 久久国产精品色婷婷| 久久理论片午夜琪琪电影网| 亚洲国产一区二区三区a毛片 | 久热精品在线视频| 麻豆免费精品视频| 亚洲一级片在线看| 久久精品日韩欧美| 一本色道久久综合一区| 午夜精品久久| 亚洲午夜在线观看| 久久久精品tv| 亚洲免费网址| 米奇777在线欧美播放| 亚洲资源av| 久久久夜夜夜| 亚洲永久视频| 亚洲高清色综合| 久久精品夜色噜噜亚洲a∨| 亚洲精品麻豆| 性欧美暴力猛交69hd| 亚洲美女黄色片| 欧美综合第一页| 在线一区二区视频| 麻豆精品精华液| 亚洲一级黄色片| 欧美成人蜜桃| 久久精品最新地址| 国产精品家庭影院| 欧美a级片网| 国产日本欧美一区二区三区| 亚洲精品一级| 亚洲黄色在线视频| 欧美一区国产在线| 亚洲综合第一| 欧美日韩国产大片| 欧美精品一区在线播放| 亚洲一区二区三区中文字幕在线 | 久久午夜电影网| 在线观看日韩www视频免费| 久久艳片www.17c.com| 亚洲日本成人| 久久丁香综合五月国产三级网站| 国内久久视频| 欧美日韩在线影院| 欧美日韩精品一区二区| 女人色偷偷aa久久天堂| 国产农村妇女精品| 亚洲免费中文字幕| 亚洲天堂av电影| 欧美日韩免费在线观看| 亚洲人在线视频| 亚洲精品日韩在线观看| 亚洲欧洲另类| 亚洲午夜在线| 中文精品一区二区三区| 欧美大片专区| 欧美激情精品久久久久久变态| 国产一区二区三区久久久| 亚洲欧美一区二区原创| 欧美在线关看| 国语自产精品视频在线看一大j8 | 乱中年女人伦av一区二区| 可以免费看不卡的av网站| 亚洲日本中文| 亚洲视频在线看| 欧美大香线蕉线伊人久久国产精品| 久久天堂国产精品| 狠狠久久婷婷| 久久免费国产精品| 欧美91福利在线观看| 亚洲国产专区校园欧美| 欧美久久电影| 亚洲在线视频一区| 久久九九全国免费精品观看| 韩国福利一区| 欧美激情综合在线| 亚洲夜晚福利在线观看| 毛片精品免费在线观看| 国产婷婷成人久久av免费高清 | 国产精品高潮呻吟视频| 男女激情久久| 国产精品看片你懂得| 亚洲一级片在线观看| 亚洲国产电影| 欧美精品一卡二卡| 亚洲一区免费视频| 欧美1区2区| 亚洲视频在线看| 国产综合久久| 欧美顶级艳妇交换群宴| 一区二区不卡在线视频 午夜欧美不卡在| 亚洲尤物影院| 在线观看欧美| 欧美午夜精品理论片a级按摩 | 黄色成人在线免费| 午夜精品久久久久久久99水蜜桃| 久久伊人精品天天| 亚洲一区二区欧美日韩| 激情视频一区二区| 国产精品国产a级| 久久在线精品| 亚洲午夜小视频| 亚洲国产成人av好男人在线观看| 亚洲一区自拍| 亚洲美女少妇无套啪啪呻吟| 国产日韩欧美综合一区| 欧美片第一页| 久热精品在线| 欧美大胆人体视频| 国产美女诱惑一区二区| 欧美第一黄网免费网站| 亚洲欧美日韩国产精品| 洋洋av久久久久久久一区| 欧美激情中文字幕一区二区| 久久久久久亚洲综合影院红桃 | 亚洲天堂av图片| 久久精品欧洲| 亚洲综合不卡| 99精品视频网| 亚洲第一免费播放区| 欧美91精品| 欧美大片国产精品| 亚洲国产精品999| 亚洲国产毛片完整版 | 欧美一区二区视频在线| av成人动漫| 国产一区二区三区电影在线观看| 久久精品2019中文字幕| 麻豆精品在线播放| 国产精品嫩草久久久久| 欧美日韩国产高清| 欧美精品一区二区三区在线看午夜 | 久久国产精品高清| 亚洲综合电影一区二区三区| 一区二区三区久久精品| 91久久久久久久久| 亚洲激情网址| 亚洲精品一区二区在线| 亚洲青涩在线| 亚洲毛片在线看| 日韩视频在线免费| 中文国产亚洲喷潮| 亚洲欧美日韩第一区| 午夜精品免费在线| 欧美一区日本一区韩国一区| 欧美与黑人午夜性猛交久久久| 午夜精品久久久久久99热| 性色av一区二区三区在线观看 | 亚洲视频精选| 亚洲欧美成人在线| 午夜伦理片一区| 久久精精品视频| 久久综合狠狠综合久久激情| 蜜臀久久99精品久久久久久9 | 在线观看视频一区二区| 亚洲国产91| 久久综合九色综合欧美就去吻| 激情久久久久久久|