2017-02-01 17 views
0

Я запускаю регистратор slf4j в системе akka. Если система работает на низкой памяти, я получаю OutOfMemoryError в консоли. Однако это не отображается в файле журнала. Это затрудняет обнаружение этих ошибок, так как я должен их замечать, прежде чем они исчезнут с верхней части консоли. Есть ли способ заставить их также отображаться в файле журнала?Как записать OutOfMemoryError в slf4j

Это ошибка:

[error] (pool-21-thread-22) java.lang.OutOfMemoryError: Java heap space 
java.lang.OutOfMemoryError: Java heap space 
     at java.util.Arrays.copyOf(Unknown Source) 
     at java.lang.AbstractStringBuilder.expandCapacity(Unknown Source) 
     at java.lang.AbstractStringBuilder.ensureCapacityInternal(Unknown Source) 
     .... 

И это мой logback.xml, который я думал, что настроить, чтобы дать точно такой же вывод в файл журнала против консоли:

<configuration> 

    <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender"> 
    <encoder> 
     <pattern>%d{HH:mm:ss.SSS} %-5level [%X{akkaSource}] %logger{36} - %msg%n</pattern> 
    </encoder> 
    </appender> 

    <appender name="FILE" class="ch.qos.logback.core.FileAppender"> 
    <file>log/akka.log</file> 
    <append>false</append> 
    <encoder> 
     <pattern>%d{HH:mm:ss.SSS} %-5level [%X{akkaSource}] [%thread] %logger{36} - %msg%n</pattern> 
    </encoder> 
    </appender> 

    <logger name="slick" level="INFO"> 
    </logger> 

    <logger name="myserver" level="DEBUG"> 
    </logger> 

    <logger name="akka" level="DEBUG"> 
    </logger> 

    <logger name="spray" level="DEBUG"> 
    </logger> 

    <root level="DEBUG"> 
    <appender-ref ref="CONSOLE" /> 
    <appender-ref ref="FILE" /> 
    </root> 

</configuration> 

Большинство других ошибок появляются как в консоли, так и в файле журнала, но не в OutOfMemoryError. Благодарю.

ответ

0

С Scalatra я получил OOM показать на бревнах, добавив error в MyServlet extending ScalatraServlet:

error { 
    case t: Throwable => { 
    logger.error(s"Unexpected throwable: ${t.toString}", t) 
    throw t 
    } 
} 

 Смежные вопросы

  • Нет связанных вопросов^_^