HBASE-8667 Master and Regionserver not able to communicate if both bound to different network interfaces on the same machine

git-svn-id: https://svn.apache.org/repos/asf/hbase/trunk@1514427 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Michael Stack 2013-08-15 18:25:58 +00:00
parent 72eacc89f3
commit 11b7da45ec
2 changed files with 34 additions and 4 deletions

View File

@ -30,6 +30,7 @@ import java.io.OutputStream;
import java.net.ConnectException; import java.net.ConnectException;
import java.net.InetSocketAddress; import java.net.InetSocketAddress;
import java.net.Socket; import java.net.Socket;
import java.net.SocketAddress;
import java.net.SocketException; import java.net.SocketException;
import java.net.SocketTimeoutException; import java.net.SocketTimeoutException;
import java.net.UnknownHostException; import java.net.UnknownHostException;
@ -125,6 +126,7 @@ public class RpcClient {
protected final SocketFactory socketFactory; // how to create sockets protected final SocketFactory socketFactory; // how to create sockets
protected String clusterId; protected String clusterId;
protected final SocketAddress localAddr;
private final boolean fallbackAllowed; private final boolean fallbackAllowed;
@ -553,6 +555,9 @@ public class RpcClient {
this.socket = socketFactory.createSocket(); this.socket = socketFactory.createSocket();
this.socket.setTcpNoDelay(tcpNoDelay); this.socket.setTcpNoDelay(tcpNoDelay);
this.socket.setKeepAlive(tcpKeepAlive); this.socket.setKeepAlive(tcpKeepAlive);
if (localAddr != null) {
this.socket.bind(localAddr);
}
// connection time out is 20s // connection time out is 20s
NetUtils.connect(this.socket, remoteId.getAddress(), NetUtils.connect(this.socket, remoteId.getAddress(),
getSocketTimeout(conf)); getSocketTimeout(conf));
@ -1213,13 +1218,25 @@ public class RpcClient {
super(msg); super(msg);
} }
} }
/**
* Construct an IPC cluster client whose values are of the {@link Message} class.
* @param conf configuration
* @param clusterId
* @param factory socket factory
*/
RpcClient(Configuration conf, String clusterId, SocketFactory factory) {
this(conf, clusterId, factory, null);
}
/** /**
* Construct an IPC cluster client whose values are of the {@link Message} class. * Construct an IPC cluster client whose values are of the {@link Message} class.
* @param conf configuration * @param conf configuration
* @param clusterId
* @param factory socket factory * @param factory socket factory
* @param localAddr client socket bind address
*/ */
RpcClient(Configuration conf, String clusterId, SocketFactory factory) { RpcClient(Configuration conf, String clusterId, SocketFactory factory, SocketAddress localAddr) {
this.maxIdleTime = conf.getInt("hbase.ipc.client.connection.maxidletime", 10000); //10s this.maxIdleTime = conf.getInt("hbase.ipc.client.connection.maxidletime", 10000); //10s
this.maxRetries = conf.getInt("hbase.ipc.client.connect.max.retries", 0); this.maxRetries = conf.getInt("hbase.ipc.client.connect.max.retries", 0);
this.failureSleep = conf.getInt("hbase.client.pause", 1000); this.failureSleep = conf.getInt("hbase.client.pause", 1000);
@ -1236,6 +1253,7 @@ public class RpcClient {
this.failedServers = new FailedServers(conf); this.failedServers = new FailedServers(conf);
this.fallbackAllowed = conf.getBoolean(IPC_CLIENT_FALLBACK_TO_SIMPLE_AUTH_ALLOWED_KEY, this.fallbackAllowed = conf.getBoolean(IPC_CLIENT_FALLBACK_TO_SIMPLE_AUTH_ALLOWED_KEY,
IPC_CLIENT_FALLBACK_TO_SIMPLE_AUTH_ALLOWED_DEFAULT); IPC_CLIENT_FALLBACK_TO_SIMPLE_AUTH_ALLOWED_DEFAULT);
this.localAddr = localAddr;
if (LOG.isDebugEnabled()) { if (LOG.isDebugEnabled()) {
LOG.debug("Codec=" + this.codec + ", compressor=" + this.compressor + LOG.debug("Codec=" + this.codec + ", compressor=" + this.compressor +
", tcpKeepAlive=" + this.tcpKeepAlive + ", tcpKeepAlive=" + this.tcpKeepAlive +
@ -1243,7 +1261,8 @@ public class RpcClient {
", maxIdleTime=" + this.maxIdleTime + ", maxIdleTime=" + this.maxIdleTime +
", maxRetries=" + this.maxRetries + ", maxRetries=" + this.maxRetries +
", fallbackAllowed=" + this.fallbackAllowed + ", fallbackAllowed=" + this.fallbackAllowed +
", ping interval=" + this.pingInterval + "ms."); ", ping interval=" + this.pingInterval + "ms" +
", bind address=" + (this.localAddr != null ? this.localAddr : "null"));
} }
} }
@ -1253,7 +1272,17 @@ public class RpcClient {
* @param clusterId * @param clusterId
*/ */
public RpcClient(Configuration conf, String clusterId) { public RpcClient(Configuration conf, String clusterId) {
this(conf, clusterId, NetUtils.getDefaultSocketFactory(conf)); this(conf, clusterId, NetUtils.getDefaultSocketFactory(conf), null);
}
/**
* Construct an IPC client for the cluster <code>clusterId</code> with the default SocketFactory
* @param conf configuration
* @param clusterId
* @param localAddr client socket bind address.
*/
public RpcClient(Configuration conf, String clusterId, SocketAddress localAddr) {
this(conf, clusterId, NetUtils.getDefaultSocketFactory(conf), localAddr);
} }
/** /**

View File

@ -777,7 +777,8 @@ public class HRegionServer implements ClientProtos.ClientService.BlockingInterfa
movedRegionsCleaner = MovedRegionsCleaner.createAndStart(this); movedRegionsCleaner = MovedRegionsCleaner.createAndStart(this);
// Setup RPC client for master communication // Setup RPC client for master communication
rpcClient = new RpcClient(conf, clusterId); rpcClient = new RpcClient(conf, clusterId, new InetSocketAddress(
this.isa.getAddress(), 0));
} }
/** /**