HBASE-12056 RPC logging too much in DEBUG mode

This commit is contained in:
Enis Soztutar 2014-09-23 19:53:57 -07:00
parent c32af7df5f
commit 48aa009581
2 changed files with 27 additions and 19 deletions

View File

@ -27,7 +27,6 @@ import com.google.protobuf.Message.Builder;
import com.google.protobuf.RpcCallback; import com.google.protobuf.RpcCallback;
import com.google.protobuf.RpcController; import com.google.protobuf.RpcController;
import com.google.protobuf.ServiceException; import com.google.protobuf.ServiceException;
import com.google.protobuf.TextFormat;
import org.apache.commons.logging.Log; import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory; import org.apache.commons.logging.LogFactory;
import org.apache.hadoop.classification.InterfaceAudience; import org.apache.hadoop.classification.InterfaceAudience;
@ -114,8 +113,6 @@ import java.util.concurrent.atomic.AtomicInteger;
@SuppressWarnings("SynchronizationOnLocalVariableOrMethodParameter") @SuppressWarnings("SynchronizationOnLocalVariableOrMethodParameter")
@InterfaceAudience.Private @InterfaceAudience.Private
public class RpcClient { public class RpcClient {
// The LOG key is intentionally not from this package to avoid ipc logging at DEBUG (all under
// o.a.h.hbase is set to DEBUG as default).
public static final Log LOG = LogFactory.getLog(RpcClient.class); public static final Log LOG = LogFactory.getLog(RpcClient.class);
protected final PoolMap<ConnectionId, Connection> connections; protected final PoolMap<ConnectionId, Connection> connections;
@ -436,6 +433,7 @@ public class RpcClient {
return cts; return cts;
} }
@Override
public void close(){ public void close(){
assert shouldCloseConnection.get(); assert shouldCloseConnection.get();
callsToWrite.offer(CallFuture.DEATH_PILL); callsToWrite.offer(CallFuture.DEATH_PILL);
@ -769,8 +767,8 @@ public class RpcClient {
@Override @Override
public void run() { public void run() {
if (LOG.isDebugEnabled()) { if (LOG.isTraceEnabled()) {
LOG.debug(getName() + ": starting, connections " + connections.size()); LOG.trace(getName() + ": starting, connections " + connections.size());
} }
try { try {
@ -778,17 +776,21 @@ public class RpcClient {
readResponse(); readResponse();
} }
} catch (InterruptedException t) { } catch (InterruptedException t) {
LOG.debug(getName() + ": interrupted while waiting for call responses"); if (LOG.isTraceEnabled()) {
LOG.trace(getName() + ": interrupted while waiting for call responses");
}
markClosed(ExceptionUtil.asInterrupt(t)); markClosed(ExceptionUtil.asInterrupt(t));
} catch (Throwable t) { } catch (Throwable t) {
if (LOG.isDebugEnabled()) {
LOG.debug(getName() + ": unexpected throwable while waiting for call responses", t); LOG.debug(getName() + ": unexpected throwable while waiting for call responses", t);
}
markClosed(new IOException("Unexpected throwable while waiting call responses", t)); markClosed(new IOException("Unexpected throwable while waiting call responses", t));
} }
close(); close();
if (LOG.isDebugEnabled()) { if (LOG.isTraceEnabled()) {
LOG.debug(getName() + ": stopped, connections " + connections.size()); LOG.trace(getName() + ": stopped, connections " + connections.size());
} }
} }
@ -849,12 +851,15 @@ public class RpcClient {
final UserGroupInformation user) final UserGroupInformation user)
throws IOException, InterruptedException{ throws IOException, InterruptedException{
user.doAs(new PrivilegedExceptionAction<Object>() { user.doAs(new PrivilegedExceptionAction<Object>() {
@Override
public Object run() throws IOException, InterruptedException { public Object run() throws IOException, InterruptedException {
closeConnection(); closeConnection();
if (shouldAuthenticateOverKrb()) { if (shouldAuthenticateOverKrb()) {
if (currRetries < maxRetries) { if (currRetries < maxRetries) {
if (LOG.isDebugEnabled()) {
LOG.debug("Exception encountered while connecting to " + LOG.debug("Exception encountered while connecting to " +
"the server : " + ex); "the server : " + ex);
}
//try re-login //try re-login
if (UserGroupInformation.isLoginKeytabBased()) { if (UserGroupInformation.isLoginKeytabBased()) {
UserGroupInformation.getLoginUser().reloginFromKeytab(); UserGroupInformation.getLoginUser().reloginFromKeytab();
@ -1048,14 +1053,14 @@ public class RpcClient {
disposeSasl(); disposeSasl();
// log the info // log the info
if (LOG.isDebugEnabled()) { if (LOG.isTraceEnabled()) {
LOG.debug(getName() + ": closing ipc connection to " + server); LOG.trace(getName() + ": closing ipc connection to " + server);
} }
cleanupCalls(true); cleanupCalls(true);
if (LOG.isDebugEnabled()) { if (LOG.isTraceEnabled()) {
LOG.debug(getName() + ": ipc connection to " + server + " closed"); LOG.trace(getName() + ": ipc connection to " + server + " closed");
} }
} }
@ -1222,8 +1227,8 @@ public class RpcClient {
if (e == null) throw new NullPointerException(); if (e == null) throw new NullPointerException();
if (shouldCloseConnection.compareAndSet(false, true)) { if (shouldCloseConnection.compareAndSet(false, true)) {
if (LOG.isDebugEnabled()) { if (LOG.isTraceEnabled()) {
LOG.debug(getName() + ": marking at should close, reason: " + e.getMessage()); LOG.trace(getName() + ": marking at should close, reason: " + e.getMessage());
} }
if (callSender != null) { if (callSender != null) {
callSender.close(); callSender.close();

View File

@ -551,6 +551,7 @@ public class RpcServer implements RpcServerInterface {
Reader() throws IOException { Reader() throws IOException {
this.readSelector = Selector.open(); this.readSelector = Selector.open();
} }
@Override
public void run() { public void run() {
try { try {
doRunLoop(); doRunLoop();
@ -1248,8 +1249,8 @@ public class RpcServer implements RpcServerInterface {
private void saslReadAndProcess(byte[] saslToken) throws IOException, private void saslReadAndProcess(byte[] saslToken) throws IOException,
InterruptedException { InterruptedException {
if (saslContextEstablished) { if (saslContextEstablished) {
if (LOG.isDebugEnabled()) if (LOG.isTraceEnabled())
LOG.debug("Have read input token of size " + saslToken.length LOG.trace("Have read input token of size " + saslToken.length
+ " for processing by saslServer.unwrap()"); + " for processing by saslServer.unwrap()");
if (!useWrap) { if (!useWrap) {
@ -2000,6 +2001,7 @@ public class RpcServer implements RpcServerInterface {
* the return response has protobuf response payload. On failure, the * the return response has protobuf response payload. On failure, the
* exception name and the stack trace are returned in the protobuf response. * exception name and the stack trace are returned in the protobuf response.
*/ */
@Override
public Pair<Message, CellScanner> call(BlockingService service, MethodDescriptor md, public Pair<Message, CellScanner> call(BlockingService service, MethodDescriptor md,
Message param, CellScanner cellScanner, long receiveTime, MonitoredRPCHandler status) Message param, CellScanner cellScanner, long receiveTime, MonitoredRPCHandler status)
throws IOException { throws IOException {
@ -2154,6 +2156,7 @@ public class RpcServer implements RpcServerInterface {
/** /**
* Returns the metrics instance for reporting RPC call statistics * Returns the metrics instance for reporting RPC call statistics
*/ */
@Override
public MetricsHBaseServer getMetrics() { public MetricsHBaseServer getMetrics() {
return metrics; return metrics;
} }