在CGFT大數(shù)據(jù)中,數(shù)據(jù)錯誤與恢復(fù)是需要重點掌握的。具體有什么內(nèi)容,下文作詳細介紹!
HDFS具有較高的容錯性,可以兼容廉價的硬件,它把硬件出錯看成一種常態(tài),而不是異常,并設(shè)計了相應(yīng)的機制檢測數(shù)據(jù)錯誤和進行自行恢復(fù),主要包括以下幾種情形。
1、名稱節(jié)點出錯
名稱節(jié)點保存了所有的元數(shù)據(jù)信息,其中,核心的兩大數(shù)據(jù)結(jié)構(gòu)是fslmage和editlog。如果這兩個文件發(fā)生損壞,那么整個HDFS實例將失效。因此,HDFS設(shè)置了備份機制,把這些核心文件同步復(fù)制到備份服務(wù)器secondarynamenode上,備份服務(wù)器本身不會處理任何請求,只扮演備份機的角色,雖然這樣會增加名稱節(jié)點服務(wù)器的負擔(dān),但是,可以有效保 證數(shù)據(jù)的可靠新和系統(tǒng)可用性。
2、數(shù)據(jù)節(jié)點出錯
每個數(shù)據(jù)節(jié)點會定期向名稱節(jié)點發(fā)送“心跳”信息,向名稱節(jié)點報告自己的狀態(tài)。當(dāng)數(shù)據(jù)節(jié)點發(fā)生故障,或者網(wǎng)絡(luò)發(fā)生斷網(wǎng)時,名稱節(jié)點就無法收到來自一些數(shù)據(jù)節(jié)點的心跳信息,這時,這些數(shù)據(jù)節(jié)點就會被標(biāo)記為“宕機”,節(jié)點上面的所有數(shù)據(jù)就會被標(biāo)記為“不可讀”,名稱節(jié)點不會再給它們發(fā)送任何I/O請求。
3、數(shù)據(jù)出錯
網(wǎng)絡(luò)傳輸和磁盤錯誤等因素,都會造成數(shù)據(jù)錯誤??蛻舳嗽谧x取到數(shù)據(jù)后,會采用md5和shal對數(shù)據(jù)塊進行校驗,以確定讀取到正確的數(shù)據(jù)。
在文件被創(chuàng)建時,客戶端就會對每一個文件塊進行信息摘錄,并把這些信息寫入同一個路徑的隱藏文件里面。
當(dāng)客戶端讀取文件的時候,會先讀取該信息文件,然后,利用該信息文件對每個讀取的數(shù)據(jù)塊進行校驗,如果校驗出錯,客戶端就會請求到另外一個數(shù)據(jù)節(jié)點讀取該文件塊,并且向名稱節(jié)點報告這個文件塊有錯誤,名稱節(jié)點會定期檢查并且重新復(fù)制這個塊。
