有没有办法Throwable.printStackTrace(PrintStream s)打印完整的堆栈跟踪,以便我可以看到超出最后一行"... 40 more"?
在Java日志中很多次我会得到类似的东西:
Caused by: java.sql.BatchUpdateException: failed batch
at org.hsqldb.jdbc.jdbcStatement.executeBatch(jdbcStatement.java:1102)
at org.hsqldb.jdbc.jdbcPreparedStatement.executeBatch(jdbcPreparedStatement.java:514)
at org.hibernate.jdbc.BatchingBatcher.doExecuteBatch(BatchingBatcher.java:48)
at org.hibernate.jdbc.AbstractBatcher.executeBatch(AbstractBatcher.java:242)
... 113 more
Run Code Online (Sandbox Code Playgroud)
有谁知道如何显示完整的堆栈跟踪(即显示其他113行)?
Throwable 的JavaDocs(适用于Java 7)对发生的事情有一个非常详细的解释.
我需要编写一个小的日志分析器应用程序来处理由我的项目中使用的第三方闭源库(在里面有自定义记录器)生成的一些日志文件.
如果日志中有异常条目,我需要从异常的顶部到实际位置收集有关堆栈跟踪所涉及方法的聚合信息.
不幸的是,默认情况下,Java printStackTrace()不会打印调用堆栈中的每个方法,而是打印一定数量,其余的只是被引用为16 more....
如果我能自己捕获异常,我会使用getStackTrace()并自己打印,但根本原因从未包含在此库引发的异常中.
有没有办法让Java在堆栈跟踪中打印整个调用堆栈?
除了我的情况,常见的日志框架可以选择吗?
编辑:该程序在Sun的JVM上使用JDK 1.5.0_09运行.无法改变这一点.
我正在尝试使用抛出异常的应用程序调试问题,即使我使用-XX:MaxJavaStackTraceDepth=16777216(或那里的任何其他值,如-1或2048),堆栈跟踪也会被切断。
它是这样切断的:
Caused by: java.lang.IllegalStateException: unexpected message type: DefaultLastHttpContent
at io.netty.handler.codec.http.HttpObjectEncoder.encode(HttpObjectEncoder.java:124)
at io.netty.handler.codec.http.HttpClientCodec$Encoder.encode(HttpClientCodec.java:167)
at io.netty.handler.codec.MessageToMessageEncoder.write(MessageToMessageEncoder.java:89)
... 89 more
Run Code Online (Sandbox Code Playgroud)
我想看到更多的堆栈跟踪元素而不是... 89 more如何实现?
这是在 Java 8 中使用 SLF4J + Logback 使用以下配置进行日志记录:
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
<layout class="ch.qos.logback.classic.PatternLayout">
<Pattern>
%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} - %msg%n
</Pattern>
</layout>
</appender>
<root level="info">
<appender-ref ref="STDOUT"/>
</root>
</configuration>
Run Code Online (Sandbox Code Playgroud)