思考:如果电脑磁盘里面存储的数据是控制高铁信号灯的红灯信号(1)和绿灯信号(0),但是存储该数据的磁盘坏了,一直显示是绿灯,是否很危险?同理 DataNode 节点上的数据损坏了,却没有发现,是否也很危险,那么如何解决呢? 如下是 DataNode 节点保证数据完整性的方法。 1)当 DataNode 读取 Block 的时候,它会计算 CheckSum。 2)如果计算后的 CheckSum,与 Block 创建时值不一样,说明 Block 已经损坏。 3)Client 读取其他 DataNode 上的 Block。 4)DataNode 在其文件创建后周期验证 CheckSum
