如何启用日志记录堆栈跟踪og未捕获的异常

时间:2018-06-15 14:09:25

标签: java exception logging logback

我很想回来并希望在我的应用中尝试使用它。我尝试按如下方式配置它:

<appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <file>/file/log.log</file>
    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
        <!-- daily rollover -->
        <fileNamePattern>/rotated/log.log.%d{yyyy-MM-dd}.log</fileNamePattern>

        <!-- keep 30 days' worth of history capped at 3GB total size -->
        <maxHistory>30</maxHistory>
        <totalSizeCap>16GB</totalSizeCap>
    </rollingPolicy>

    <encoder>
        <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
    </encoder>
</appender>

<root level="debug">
    <appender-ref ref="STDOUT" />
    <appender-ref ref="FILE" />
</root>

当我编写一个简单的应用程序时,我遇到了一个问题,即没有记录未捕获异常的堆栈跟踪:

public static void main(String[] args){
    logger.info("Test")
    logger.error("TEST!")
    throw new IllegalArgumentException("Exception")
}

我在日志文件中的内容是:

16:57:05.905 [main] INFO  com.App - Test
16:57:05.907 [main] ERROR com.App - TEST!

如何配置未捕获异常的日志记录堆栈跟踪?

1 个答案:

答案 0 :(得分:1)

我不认为您可以在main()方法之外记录未捕获的异常。但是你可以做的是使用&#34;赶上所有&#34;阻止你的主要方法:

public static void main(String[] args){
    try
    {
        logger.info("Test");
        logger.error("TEST!");
        someMethodThatPropablyThrowsAnException();
        throw new IllegalArgumentException("Exception");
    }
    catch (Exception exception)
    {
        logger.error(exception);
    }
}

这应该记录代码中抛出的任何未处理的异常。