HBASE-10039 Fix potential Resource Leak in RpcServer

git-svn-id: https://svn.apache.org/repos/asf/hbase/trunk@1545896 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
eclark 2013-11-27 00:57:17 +00:00
parent 9eb5a28520
commit 69daad5a47
1 changed files with 32 additions and 16 deletions

View File

@ -754,9 +754,14 @@ public class RpcServer implements RpcServerInterface {
SocketChannel channel; SocketChannel channel;
while ((channel = server.accept()) != null) { while ((channel = server.accept()) != null) {
try {
channel.configureBlocking(false); channel.configureBlocking(false);
channel.socket().setTcpNoDelay(tcpNoDelay); channel.socket().setTcpNoDelay(tcpNoDelay);
channel.socket().setKeepAlive(tcpKeepAlive); channel.socket().setKeepAlive(tcpKeepAlive);
} catch (IOException ioe) {
channel.close();
throw ioe;
}
Reader reader = getReader(); Reader reader = getReader();
try { try {
@ -1358,10 +1363,13 @@ public class RpcServer implements RpcServerInterface {
*/ */
private void doRawSaslReply(SaslStatus status, Writable rv, private void doRawSaslReply(SaslStatus status, Writable rv,
String errorClass, String error) throws IOException { String errorClass, String error) throws IOException {
ByteBufferOutputStream saslResponse = null;
DataOutputStream out = null;
try {
// In my testing, have noticed that sasl messages are usually // In my testing, have noticed that sasl messages are usually
// in the ballpark of 100-200. That's why the initial capacity is 256. // in the ballpark of 100-200. That's why the initial capacity is 256.
ByteBufferOutputStream saslResponse = new ByteBufferOutputStream(256); saslResponse = new ByteBufferOutputStream(256);
DataOutputStream out = new DataOutputStream(saslResponse); out = new DataOutputStream(saslResponse);
out.writeInt(status.state); // write status out.writeInt(status.state); // write status
if (status == SaslStatus.SUCCESS) { if (status == SaslStatus.SUCCESS) {
rv.write(out); rv.write(out);
@ -1372,6 +1380,14 @@ public class RpcServer implements RpcServerInterface {
saslCall.setSaslTokenResponse(saslResponse.getByteBuffer()); saslCall.setSaslTokenResponse(saslResponse.getByteBuffer());
saslCall.responder = responder; saslCall.responder = responder;
saslCall.sendResponseIfReady(); saslCall.sendResponseIfReady();
} finally {
if (saslResponse != null) {
saslResponse.close();
}
if (out != null) {
out.close();
}
}
} }
private void disposeSasl() { private void disposeSasl() {