关于解决错误 java.io.IOException: Cannot obtain block length for LocatedBlock{BP的方案

问题:出现这个错误 java.io.IOException: Cannot obtain block length for LocatedBlock{BP-1331

原因:文件异常关闭,导致文件,如下图错误内容

 关于解决错误 java.io.IOException: Cannot obtain block length for LocatedBlock{BP的方案_第1张图片

hdfs fsck  /data/115/apkinfo/0-11-20180410170000.log(使用命令查看文件块的状态,如下图为打开状态) 红色为hdfs上的地址

 关于解决错误 java.io.IOException: Cannot obtain block length for LocatedBlock{BP的方案_第2张图片

hdfs debug recoverLease -path  /data/115/apkinfo/0-11-20180410170000.log (对于这些状态损坏的文件来讲,rm掉的话是很暴力的做法,万一上游对应日期的数据已经没有rention呢?所以,既然没有释放租约,那么恢复租约close掉文件就是了) 红色为hdfs上的地址  

 

hdfs   fsck  /data/115/apkinfo/0-11-20180410170000.log(再查看状态显示块已经正常)

 关于解决错误 java.io.IOException: Cannot obtain block length for LocatedBlock{BP的方案_第3张图片

问题解决

你可能感兴趣的:(Hadoop相关)