HADOOP-18628. IPC Server Connection should log host name before returning VersionMismatch error (#5385)
Contributed by Viraj Jasani
This commit is contained in:
parent
fe0541b58d
commit
021fcc6c5e
@ -1985,11 +1985,26 @@ public class Connection {
|
|||||||
private long lastContact;
|
private long lastContact;
|
||||||
private int dataLength;
|
private int dataLength;
|
||||||
private Socket socket;
|
private Socket socket;
|
||||||
|
|
||||||
// Cache the remote host & port info so that even if the socket is
|
// Cache the remote host & port info so that even if the socket is
|
||||||
// disconnected, we can say where it used to connect to.
|
// disconnected, we can say where it used to connect to.
|
||||||
private String hostAddress;
|
|
||||||
private int remotePort;
|
/**
|
||||||
private InetAddress addr;
|
* Client Host IP address from where the socket connection is being established to the Server.
|
||||||
|
*/
|
||||||
|
private final String hostAddress;
|
||||||
|
/**
|
||||||
|
* Client remote port used for the given socket connection.
|
||||||
|
*/
|
||||||
|
private final int remotePort;
|
||||||
|
/**
|
||||||
|
* Address to which the socket is connected to.
|
||||||
|
*/
|
||||||
|
private final InetAddress addr;
|
||||||
|
/**
|
||||||
|
* Client Host address from where the socket connection is being established to the Server.
|
||||||
|
*/
|
||||||
|
private final String hostName;
|
||||||
|
|
||||||
IpcConnectionContextProto connectionContext;
|
IpcConnectionContextProto connectionContext;
|
||||||
String protocolName;
|
String protocolName;
|
||||||
@ -2033,8 +2048,12 @@ public Connection(SocketChannel channel, long lastContact,
|
|||||||
this.isOnAuxiliaryPort = isOnAuxiliaryPort;
|
this.isOnAuxiliaryPort = isOnAuxiliaryPort;
|
||||||
if (addr == null) {
|
if (addr == null) {
|
||||||
this.hostAddress = "*Unknown*";
|
this.hostAddress = "*Unknown*";
|
||||||
|
this.hostName = this.hostAddress;
|
||||||
} else {
|
} else {
|
||||||
|
// host IP address
|
||||||
this.hostAddress = addr.getHostAddress();
|
this.hostAddress = addr.getHostAddress();
|
||||||
|
// host name for the IP address
|
||||||
|
this.hostName = addr.getHostName();
|
||||||
}
|
}
|
||||||
this.remotePort = socket.getPort();
|
this.remotePort = socket.getPort();
|
||||||
this.responseQueue = new LinkedList<RpcCall>();
|
this.responseQueue = new LinkedList<RpcCall>();
|
||||||
@ -2050,7 +2069,7 @@ public Connection(SocketChannel channel, long lastContact,
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return getHostAddress() + ":" + remotePort;
|
return hostName + ":" + remotePort + " / " + hostAddress + ":" + remotePort;
|
||||||
}
|
}
|
||||||
|
|
||||||
boolean setShouldClose() {
|
boolean setShouldClose() {
|
||||||
@ -2463,19 +2482,18 @@ public int readAndProcess() throws IOException, InterruptedException {
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!RpcConstants.HEADER.equals(dataLengthBuffer)) {
|
if (!RpcConstants.HEADER.equals(dataLengthBuffer)) {
|
||||||
LOG.warn("Incorrect RPC Header length from {}:{} "
|
LOG.warn("Incorrect RPC Header length from {}:{} / {}:{}. Expected: {}. Actual: {}",
|
||||||
+ "expected length: {} got length: {}",
|
hostName, remotePort, hostAddress, remotePort, RpcConstants.HEADER,
|
||||||
hostAddress, remotePort, RpcConstants.HEADER, dataLengthBuffer);
|
dataLengthBuffer);
|
||||||
setupBadVersionResponse(version);
|
setupBadVersionResponse(version);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
if (version != CURRENT_VERSION) {
|
if (version != CURRENT_VERSION) {
|
||||||
//Warning is ok since this is not supposed to happen.
|
//Warning is ok since this is not supposed to happen.
|
||||||
LOG.warn("Version mismatch from " +
|
LOG.warn("Version mismatch from {}:{} / {}:{}. "
|
||||||
hostAddress + ":" + remotePort +
|
+ "Expected version: {}. Actual version: {} ", hostName,
|
||||||
" got version " + version +
|
remotePort, hostAddress, remotePort, CURRENT_VERSION, version);
|
||||||
" expected version " + CURRENT_VERSION);
|
|
||||||
setupBadVersionResponse(version);
|
setupBadVersionResponse(version);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
@ -1168,6 +1168,10 @@ private static void callAndVerify(Server server, InetSocketAddress addr,
|
|||||||
|
|
||||||
call(client, addr, serviceClass, conf);
|
call(client, addr, serviceClass, conf);
|
||||||
Connection connection = server.getConnections()[0];
|
Connection connection = server.getConnections()[0];
|
||||||
|
LOG.info("Connection is from: {}", connection);
|
||||||
|
assertEquals(
|
||||||
|
"Connection string representation should include both IP address and Host name", 2,
|
||||||
|
connection.toString().split(" / ").length);
|
||||||
int serviceClass2 = connection.getServiceClass();
|
int serviceClass2 = connection.getServiceClass();
|
||||||
assertFalse(noChanged ^ serviceClass == serviceClass2);
|
assertFalse(noChanged ^ serviceClass == serviceClass2);
|
||||||
client.stop();
|
client.stop();
|
||||||
|
@ -1849,6 +1849,11 @@ public RpcStatusProto getRpcStatusProto() {
|
|||||||
// if it wasn't fatal, verify there's only one open connection.
|
// if it wasn't fatal, verify there's only one open connection.
|
||||||
Connection[] conns = server.getConnections();
|
Connection[] conns = server.getConnections();
|
||||||
assertEquals(reqName, 1, conns.length);
|
assertEquals(reqName, 1, conns.length);
|
||||||
|
String connectionInfo = conns[0].toString();
|
||||||
|
LOG.info("Connection is from: {}", connectionInfo);
|
||||||
|
assertEquals(
|
||||||
|
"Connection string representation should include both IP address and Host name", 2,
|
||||||
|
connectionInfo.split(" / ").length);
|
||||||
// verify whether the connection should have been reused.
|
// verify whether the connection should have been reused.
|
||||||
if (isDisconnected) {
|
if (isDisconnected) {
|
||||||
assertNotSame(reqName, lastConn, conns[0]);
|
assertNotSame(reqName, lastConn, conns[0]);
|
||||||
|
Loading…
Reference in New Issue
Block a user