Подтвердить что ты не робот

Остановка системы резервного копирования для чистого завершения

Недавно я экспериментировал с logback и запускал примеры непосредственно изнутри Eclipse. Когда я это делаю, я замечаю, что даже после завершения моего статического метода main(String[] args) (изнутри моего класса Java-драйвера) приложение продолжает работать.

В конечном итоге я установил, что Logback управляет своими потоками, которые остаются в живых даже после выхода моего основного приложения. Я искал некоторые решения и нашел это как способ явного отключения Logback изнутри Java:

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

Является ли это единственным способом полного закрытия журнала? Я никогда не сталкивался с системой ведения журнала (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>[email protected]</to>
        <from>[email protected]</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.

4b9b3361

Ответ 1

Проблема, вероятно, связана с ошибкой в ​​logback. Установка asynchronousSending в true в SMTPAppender обходит ошибку (фактически не фиксируя ее). Я добавил новую проблему в нашей jira, описывающую проблему.