Pārlūkot izejas kodu

HDFS-1118. Fix socketleak on DFSClient.
(Zheng Shao via dhruba)



git-svn-id: https://svn.apache.org/repos/asf/hadoop/common/branches/branch-0.20-append@956329 13f79535-47bb-0310-9956-ffa450edef68

Dhruba Borthakur 15 gadi atpakaļ
vecāks
revīzija
00a7b4d824
2 mainītis faili ar 12 papildinājumiem un 2 dzēšanām
  1. 3 0
      CHANGES.txt
  2. 9 2
      src/hdfs/org/apache/hadoop/hdfs/DFSClient.java

+ 3 - 0
CHANGES.txt

@@ -65,6 +65,9 @@ Release 0.20-append - Unreleased
     HDFS-1211. Block receiver should not log "rewind" packets at INFO level.
     (Todd Lipcon via dhruba)
 
+    HDFS-1118. Fix socketleak on DFSClient. 
+    (Zheng Shao via dhruba)
+
 Release 0.20.3 - Unreleased
 
   NEW FEATURES

+ 9 - 2
src/hdfs/org/apache/hadoop/hdfs/DFSClient.java

@@ -2926,6 +2926,7 @@ public class DFSClient implements FSConstants, java.io.Closeable {
       // persist blocks on namenode on next flush
       persistBlocks = true;
 
+      boolean result = false;
       try {
         LOG.debug("Connecting to " + nodes[0].getName());
         InetSocketAddress target = NetUtils.createSocketAddr(nodes[0].getName());
@@ -2968,7 +2969,7 @@ public class DFSClient implements FSConstants, java.io.Closeable {
         }
 
         blockStream = out;
-        return true;     // success
+        result = true;     // success
 
       } catch (IOException ie) {
 
@@ -2986,8 +2987,14 @@ public class DFSClient implements FSConstants, java.io.Closeable {
         hasError = true;
         setLastException(ie);
         blockReplyStream = null;
-        return false;  // error
+        result = false;
+      } finally {
+        if (!result) {
+          IOUtils.closeSocket(s);
+          s = null;
+        }
       }
+      return result;
     }
   
     private LocatedBlock locateFollowingBlock(long start,