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:
parent
72eacc89f3
commit
11b7da45ec
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -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));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
Loading…
Reference in New Issue