HDFS-15199. NPE in BlockSender. Contributed by Ayush Saxena.
This commit is contained in:
parent
3937abddbd
commit
d33aec93f1
|
@ -664,18 +664,21 @@ class BlockSender implements java.io.Closeable {
|
|||
* It was done here because the NIO throws an IOException for EPIPE.
|
||||
*/
|
||||
String ioem = e.getMessage();
|
||||
if (ioem != null) {
|
||||
/*
|
||||
* If we got an EIO when reading files or transferTo the client socket,
|
||||
* it's very likely caused by bad disk track or other file corruptions.
|
||||
* If we got an EIO when reading files or transferTo the client
|
||||
* socket, it's very likely caused by bad disk track or other file
|
||||
* corruptions.
|
||||
*/
|
||||
if (ioem.startsWith(EIO_ERROR)) {
|
||||
throw new DiskFileCorruptException("A disk IO error occurred", e);
|
||||
}
|
||||
if (!ioem.startsWith("Broken pipe") && !ioem.startsWith("Connection reset")) {
|
||||
if (!ioem.startsWith("Broken pipe")
|
||||
&& !ioem.startsWith("Connection reset")) {
|
||||
LOG.error("BlockSender.sendChunks() exception: ", e);
|
||||
datanode.getBlockScanner().markSuspectBlock(
|
||||
ris.getVolumeRef().getVolume().getStorageID(),
|
||||
block);
|
||||
ris.getVolumeRef().getVolume().getStorageID(), block);
|
||||
}
|
||||
}
|
||||
}
|
||||
throw ioeToSocketException(e);
|
||||
|
|
Loading…
Reference in New Issue