From cd55d90507e788d7a862c2255ad9cbf89647fc7f Mon Sep 17 00:00:00 2001 From: Hamlin Li Date: Thu, 28 Nov 2019 13:48:25 +0800 Subject: [PATCH] 8232446: logging enhancement for rmi when socket closed Reviewed-by: rriggs, plevart --- .../sun/rmi/transport/tcp/TCPConnection.java | 5 ++- .../sun/rmi/transport/tcp/TCPTransport.java | 32 +++++++++++++++++++ 2 files changed, 36 insertions(+), 1 deletion(-) diff --git a/src/java.rmi/share/classes/sun/rmi/transport/tcp/TCPConnection.java b/src/java.rmi/share/classes/sun/rmi/transport/tcp/TCPConnection.java index 8b5a610005b..e3341b0f240 100644 --- a/src/java.rmi/share/classes/sun/rmi/transport/tcp/TCPConnection.java +++ b/src/java.rmi/share/classes/sun/rmi/transport/tcp/TCPConnection.java @@ -209,7 +209,10 @@ public class TCPConnection implements Connection { * Close the connection. */ public void close() throws IOException { - TCPTransport.tcpLog.log(Log.BRIEF, "close connection"); + if (TCPTransport.tcpLog.isLoggable(Log.BRIEF)) { + TCPTransport.tcpLog.log(Log.BRIEF, + "close connection, socket: " + socket); + } if (socket != null) socket.close(); diff --git a/src/java.rmi/share/classes/sun/rmi/transport/tcp/TCPTransport.java b/src/java.rmi/share/classes/sun/rmi/transport/tcp/TCPTransport.java index 251b7f6cef8..dd15491f1e3 100644 --- a/src/java.rmi/share/classes/sun/rmi/transport/tcp/TCPTransport.java +++ b/src/java.rmi/share/classes/sun/rmi/transport/tcp/TCPTransport.java @@ -273,12 +273,23 @@ public class TCPTransport extends Transport { private void decrementExportCount() { assert Thread.holdsLock(this); exportCount--; + if (tcpLog.isLoggable(Log.VERBOSE)) { + tcpLog.log(Log.VERBOSE, + "server socket: " + server + ", exportCount: " + exportCount); + } if (exportCount == 0 && getEndpoint().getListenPort() != 0) { ServerSocket ss = server; server = null; try { + if (tcpLog.isLoggable(Log.BRIEF)) { + tcpLog.log(Log.BRIEF, "server socket close: " + ss); + } ss.close(); } catch (IOException e) { + if (tcpLog.isLoggable(Log.BRIEF)) { + tcpLog.log(Log.BRIEF, + "server socket close throws: " + e); + } } } } @@ -366,6 +377,10 @@ public class TCPTransport extends Transport { executeAcceptLoop(); } finally { try { + if (tcpLog.isLoggable(Log.BRIEF)) { + tcpLog.log(Log.BRIEF, + "server socket close: " + serverSocket); + } /* * Only one accept loop is started per server * socket, so after no more connections will be @@ -374,6 +389,10 @@ public class TCPTransport extends Transport { */ serverSocket.close(); } catch (IOException e) { + if (tcpLog.isLoggable(Log.BRIEF)) { + tcpLog.log(Log.BRIEF, + "server socket close throws: " + e); + } } } } @@ -524,9 +543,15 @@ public class TCPTransport extends Transport { /** close socket and eat exception */ private static void closeSocket(Socket sock) { try { + if (tcpLog.isLoggable(Log.BRIEF)) { + tcpLog.log(Log.BRIEF, "socket close: " + sock); + } sock.close(); } catch (IOException ex) { // eat exception + if (tcpLog.isLoggable(Log.BRIEF)) { + tcpLog.log(Log.BRIEF, "socket close throws: " + ex); + } } } @@ -591,6 +616,9 @@ public class TCPTransport extends Transport { conn.close(); } catch (IOException ex) { // eat exception + if (tcpLog.isLoggable(Log.BRIEF)) { + tcpLog.log(Log.BRIEF, "Connection close throws " + ex); + } } } } @@ -723,6 +751,10 @@ public class TCPTransport extends Transport { // just close socket: this would recurse if we marshal an // exception to the client and the protocol at other end // doesn't match. + if (tcpLog.isLoggable(Log.BRIEF)) { + tcpLog.log(Log.BRIEF, "magic or version not match: " + + magic + ", " + version); + } closeSocket(socket); return; }