10

我最近一直在尝试使用logback,并直接从 Eclipse 内部运行示例。当我这样做时,我注意到 - 即使在我的静态main(String[] args)方法结束后(从我的 Java 驱动程序类内部),应用程序仍然运行。

我最终确定 Logback 正在管理自己的线程,即使在我的主应用程序退出后它们仍然保持活动状态。我搜索了一些解决方案,发现这是从 Java 内部显式关闭 Logback 的一种方式:

ILoggerFactory factory = LoggerFactory.getILoggerFactory();
if(factory instanceof LoggerContext) {
    LoggerContext ctx = (LoggerContext)factory;
    ctx.stop();
}

这真的是彻底关闭 logback 的唯一方法吗?我从来没有遇到过一个日志系统(JUL、JCL、log4j 等),它会让你显式关闭它以便优雅地退出你的应用程序......

提前致谢!

更新:这里是logback.xml

<configuration debug="true" scan="true" scanPeriod="5 minutes">
    <appender name="logManager-consoleAppender" class="ch.qos.logback.core.ConsoleAppender">
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <level>TRACE</level>
            <onMatch>ACCEPT</onMatch>
            <onMismatch>NEUTRAL</onMismatch>
        </filter>
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <level>DEBUG</level>
            <onMatch>ACCEPT</onMatch>
            <onMismatch>DENY</onMismatch>
        </filter>
        <encoder>
            <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
        </encoder>
    </appender>

    <appender name="logManager-smtpAppender" class="ch.qos.logback.classic.net.SMTPAppender">
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <level>WARN</level>
            <onMatch>ACCEPT</onMatch>
            <onMismatch>NEUTRAL</onMismatch>
        </filter>
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <level>ERROR</level>
            <onMatch>ACCEPT</onMatch>
            <onMismatch>DENY</onMismatch>
        </filter>
        <smtpHost>my.smtp.host</smtpHost>
        <to>john.smith@example.com</to>
        <from>no-reply@example.com</from>
        <username>my_user</username>
        <password>my_password</password>
        <subject>%logger{20} - %m</subject>
        <layout class="ch.qos.logback.classic.html.HTMLLayout"/>
        <cyclicBufferTracker class="ch.qos.logback.core.spi.CyclicBufferTracker">
            <bufferSize>5</bufferSize>
        </cyclicBufferTracker>
    </appender>

    <root level="ALL">
        <appender-ref ref="logManager-consoleAppender" />
        <appender-ref ref="logManager-smtpAppender" />
    </root>
</configuration>

使用 logback-1.0.13 和 JDK 1.6u34。

4

1 回答 1

7

该问题可能是由于 logback 中的错误。在 SMTPAppender 中将asynchronousSending设置为 true 可以绕过该错误(实际上并未修复它)。我在我们的 jira 中添加了一个新问题来描述该问题。

于 2013-05-28T15:25:26.427 回答