Logback - 将 catalina 记录在单独的文件中

标签 logback apache-tomee

我使用 Logback-Logging-Framework 配置了 TomEE,我需要将 TomEE/Catalina 输出记录到额外的 catalina.out 文件,而通常所有日志记录都会发送到应用程序.log

我提出了以下配置,但在我的 catalina.out 文件中仍然是所有 hibernate 语句..如何分离日志记录语句? 如何仅在单独的文件中记录给定的包?

<?xml version="1.0" encoding="UTF-8"?>
<!-- http://logback.qos.ch/manual/configuration.html -->
<configuration scan="true" scanPeriod="60 seconds">

<contextListener class="ch.qos.logback.classic.jul.LevelChangePropagator" />

<!-- =============================================== -->
<!-- Logging TomEE/Catalina -->
<!-- =============================================== -->

<appender class="ch.qos.logback.core.FileAppender" name="FILE-CATALINA">
    <file>${catalina.base}/logs/catalina.out</file>
    <encoder>
        <pattern>%d %-5p: [%c] %m %rEx{20} %n</pattern>
    </encoder>
</appender>

<logger name="org.apache.catalina" level="INFO" additivity="false">
    <appender-ref ref="FILE-CATALINA" />
</logger>

<!-- =============================================== -->
<!-- Logging Application -->
<!-- =============================================== -->

<appender class="ch.qos.logback.core.FileAppender" name="FILE-APP">
    <file>${catalina.base}/logs/application.log</file>
    <encoder>
        <pattern>%d %-5p: [%c] %m %rEx{3} %n</pattern>
    </encoder>
</appender>

<logger name="org.hibernate" level="INFO" />
<logger name="org.apache" level="INFO" />
<logger name="org.quartz" level="INFO" />

<!-- =============================================== -->
<!-- ROOT Logger -->
<!-- =============================================== -->

<root level="ERROR">
    <!-- log packages with INFO and all errors -->
    <appender-ref ref="FILE-APP" />
</root>

<root level="OFF">
    <!-- only log package org.apache.catalina -->
    <appender-ref ref="FILE-CATALINA" />
</root>
</configuration>

现在catalina.out日志仍然有hibernate日志(因为hibernate配置为INFO):

2015-04-30 13:38:24,004 INFO : [org.apache.catalina.startup.Catalina] Initialization processed in 4949 ms
2015-04-30 13:38:24,033 INFO : [**org.apache.catalina**.core.StandardService] Starting service Catalina
2015-04-30 13:38:24,034 INFO : [org.apache.catalina.core.StandardEngine] Starting Servlet Engine: Apache Tomcat (TomEE)/7.0.47 (1.6.0)
2015-04-30 13:38:28,484 INFO : [org.hibernate.annotations.common.Version] HCANN000001: Hibernate Commons Annotations {4.0.2.Final}
2015-04-30 13:38:28,506 INFO : [org.hibernate.Version] HHH000412: Hibernate Core {4.2.8.Final}

最佳答案

刚刚弄清楚:

我删除了第二个根附加程序(根级别 =“OFF”...),并且附加程序 FILE-CATALINA 仅从配置的附加程序引用中获取消息(不再有根级别消息)。

关于Logback - 将 catalina 记录在单独的文件中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29967425/

相关文章:

java - Spring下如何配置Logback

java - SLF4J Logger 有时会清除控制台输出(不需要)

java - 为什么在 TomEE 上远程调用 EJB 时会收到 AuthenticationException?

playframework-2.0 - PlayFramework Logback 打印调用者类名

java - Logback:选择性屏蔽语句和谨慎模式

java - 按级别分隔logback日志

java - Datastax 驱动程序日志级别

java - 当使用系统属性定义资源时,获取 SQLException : Driver:org. hsqldb.jdbcDriver 在 tomee 中为 URL 返回 null

javax.jms.JMSException : No ManagedConnections available within configured blocking timeout

java - TomEE 启动但 Netbeans 给出 "Failed to start"错误