Dávid Kaya created LOG4J2-2592:
----------------------------------
Summary: StackOverflowException when server not reachable with
SocketAppender
Key: LOG4J2-2592
URL: https://issues.apache.org/jira/browse/LOG4J2-2592
Project: Log4j 2
Issue Type: Bug
Components: Appenders
Affects Versions: 2.11.2
Reporter: Dávid Kaya
SocketAppender crashes log4j with `StackOverflowException` when the server
where the log file should be sent is not accessible. It looks like `toString`
contains recursion.
{code:java}
java.lang.StackOverflowError: null
at java.lang.Integer.toUnsignedString0(Integer.java:344) ~[?:?]
at java.lang.Integer.toHexString(Integer.java:262) ~[?:?]
at java.lang.Object.toString(Object.java:246) ~[?:?]
at java.util.concurrent.CountDownLatch.toString(CountDownLatch.java:314) ~[?:?]
at java.lang.String.valueOf(String.java:2951) ~[?:?]
at java.lang.StringBuilder.append(StringBuilder.java:168) ~[?:?]
at
org.apache.logging.log4j.core.net.TcpSocketManager$Reconnector.toString(TcpSocketManager.java:358)
~[log4j-core-2.11.0.jar:2.11.0]
at java.lang.String.valueOf(String.java:2951) ~[?:?]
at java.lang.StringBuilder.append(StringBuilder.java:168) ~[?:?]
at
org.apache.logging.log4j.core.net.TcpSocketManager.toString(TcpSocketManager.java:495)
~[log4j-core-2.11.0.jar:2.11.0]
at java.lang.String.valueOf(String.java:2951) ~[?:?]
at java.lang.StringBuilder.append(StringBuilder.java:168) ~[?:?]
at
org.apache.logging.log4j.core.net.TcpSocketManager$Reconnector.toString(TcpSocketManager.java:358)
~[log4j-core-2.11.0.jar:2.11.0]
at java.lang.String.valueOf(String.java:2951) ~[?:?]
at java.lang.StringBuilder.append(StringBuilder.java:168) ~[?:?]
at
org.apache.logging.log4j.core.net.TcpSocketManager.toString(TcpSocketManager.java:495)
~[log4j-core-2.11.0.jar:2.11.0]
at java.lang.String.valueOf(String.java:2951) ~[?:?]
at java.lang.StringBuilder.append(StringBuilder.java:168) ~[?:?]
at
org.apache.logging.log4j.core.net.TcpSocketManager$Reconnector.toString(TcpSocketManager.java:358)
~[log4j-core-2.11.0.jar:2.11.0]
at java.lang.String.valueOf(String.java:2951) ~[?:?]
at java.lang.StringBuilder.append(StringBuilder.java:168) ~[?:?]
at
org.apache.logging.log4j.core.net.TcpSocketManager.toString(TcpSocketManager.java:495)
~[log4j-core-2.11.0.jar:2.11.0]
at java.lang.String.valueOf(String.java:2951) ~[?:?]
at java.lang.StringBuilder.append(StringBuilder.java:168) ~[?:?]
at
org.apache.logging.log4j.core.net.TcpSocketManager$Reconnector.toString(TcpSocketManager.java:358)
~[log4j-core-2.11.0.jar:2.11.0]
at java.lang.String.valueOf(String.java:2951) ~[?:?]
at java.lang.StringBuilder.append(StringBuilder.java:168) ~[?:?]
at
org.apache.logging.log4j.core.net.TcpSocketManager.toString(TcpSocketManager.java:495)
~[log4j-core-2.11.0.jar:2.11.0]
at java.lang.String.valueOf(String.java:2951) ~[?:?]
at java.lang.StringBuilder.append(StringBuilder.java:168) ~[?:?]
at
org.apache.logging.log4j.core.net.TcpSocketManager$Reconnector.toString(TcpSocketManager.java:358)
~[log4j-core-2.11.0.jar:2.11.0]
at java.lang.String.valueOf(String.java:2951) ~[?:?]
at java.lang.StringBuilder.append(StringBuilder.java:168) ~[?:?]
at
org.apache.logging.log4j.core.net.TcpSocketManager.toString(TcpSocketManager.java:495)
~[log4j-core-2.11.0.jar:2.11.0]
at java.lang.String.valueOf(String.java:2951) ~[?:?]
at java.lang.StringBuilder.append(StringBuilder.java:168) ~[?:?]
at
org.apache.logging.log4j.core.net.TcpSocketManager$Reconnector.toString(TcpSocketManager.java:358)
~[log4j-core-2.11.0.jar:2.11.0]
at java.lang.String.valueOf(String.java:2951) ~[?:?]
at java.lang.StringBuilder.append(StringBuilder.java:168) ~[?:?]
at
org.apache.logging.log4j.core.net.TcpSocketManager.toString(TcpSocketManager.java:495)
~[log4j-core-2.11.0.jar:2.11.0]
at java.lang.String.valueOf(String.java:2951) ~[?:?]
at java.lang.StringBuilder.append(StringBuilder.java:168) ~[?:?]
at
org.apache.logging.log4j.core.net.TcpSocketManager$Reconnector.toString(TcpSocketManager.java:358)
~[log4j-core-2.11.0.jar:2.11.0]
at java.lang.String.valueOf(String.java:2951) ~[?:?]
at java.lang.StringBuilder.append(StringBuilder.java:168) ~[?:?]
at
org.apache.logging.log4j.core.net.TcpSocketManager.toString(TcpSocketManager.java:495)
~[log4j-core-2.11.0.jar:2.11.0]
at java.lang.String.valueOf(String.java:2951) ~[?:?]
at java.lang.StringBuilder.append(StringBuilder.java:168) ~[?:?]
at
org.apache.logging.log4j.core.net.TcpSocketManager$Reconnector.toString(TcpSocketManager.java:358)
~[log4j-core-2.11.0.jar:2.11.0]
at java.lang.String.valueOf(String.java:2951) ~[?:?]
at java.lang.StringBuilder.append(StringBuilder.java:168) ~[?:?]
at
org.apache.logging.log4j.core.net.TcpSocketManager.toString(TcpSocketManager.java:495)
~[log4j-core-2.11.0.jar:2.11.0]
at java.lang.String.valueOf(String.java:2951) ~[?:?]
at java.lang.StringBuilder.append(StringBuilder.java:168) ~[?:?]
at
...
1000s of same messages repeated in between
...
org.apache.logging.log4j.core.net.TcpSocketManager$Reconnector.toString(TcpSocketManager.java:358)
~[log4j-core-2.11.0.jar:2.11.0]
at java.lang.String.valueOf(String.java:2951) ~[?:?]
at java.lang.StringBuilder.append(StringBuilder.java:168) ~[?:?]
at
org.apache.logging.log4j.core.net.TcpSocketManager.toString(TcpSocketManager.java:495)
~[log4j-core-2.11.0.jar:2.11.0]
{code}
--
This message was sent by Atlassian JIRA
(v7.6.3#76005)