java - JBoss AS 7.1.1 Final 和 Log4j

标签 java logging log4j jboss7.x war

我知道以前曾有人问过这个问题,但任何问题的答案都没有解决我的问题。 我有一个打包为 .WAR 文件的应用程序,它在 JBoss 4.2.0 GA 上完美运行:该应用程序成功加载了我的 log4j.xml 设置。我的 log4j.xml 文件如下所示:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">

<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
  <!-- Appenders -->
  <appender name="INFO" class="org.apache.log4j.RollingFileAppender">
    <param name="File" value="/root/OnlineApp/logs/info.log" />
    <param name="MaxFileSize" value="10MB"/>
    <param name="MaxBackupIndex" value="10"/>
    <layout class="org.apache.log4j.PatternLayout">
      <param name="ConversionPattern" value="%d{dd MMM yyyy HH:mm:ss.SSS},%X{deviceId},%p,%m%n" />
    </layout>
    <filter class="org.apache.log4j.varia.LevelRangeFilter">
      <param name="LevelMin" value="INFO" />
      <param name="LevelMax" value="WARN" />
    </filter>
  </appender>
  <appender name="DEBUG" class="org.apache.log4j.RollingFileAppender">
    <param name="File" value="/root/OnlineApp/logs/debug.log" />
    <param name="MaxFileSize" value="10MB"/>
    <param name="MaxBackupIndex" value="10"/>
    <layout class="org.apache.log4j.PatternLayout">
      <param name="ConversionPattern" value="%d{dd MMM yyyy HH:mm:ss:SSS.SSS},%X{deviceId},%p,%m%n" />
    </layout>
    <filter class="org.apache.log4j.varia.LevelRangeFilter">
      <param name="LevelMin" value="TRACE" />
      <param name="LevelMax" value="DEBUG" />
    </filter>
  </appender>
  <appender name="ERRORS" class="org.apache.log4j.RollingFileAppender">
    <param name="File" value="/root/OnlineApp/logs/error.log" />
    <param name="MaxFileSize" value="10MB"/>
    <param name="MaxBackupIndex" value="10"/>
    <layout class="org.apache.log4j.PatternLayout">
      <param name="ConversionPattern" value="%d{dd MMM yyyy HH:mm:ss.SSS},%X{deviceId},%p,%m%n" />
    </layout>
    <filter class="org.apache.log4j.varia.LevelRangeFilter">
      <param name="LevelMin" value="WARN" />
      <param name="LevelMax" value="FATAL" />
    </filter>
  </appender>    
  <appender name="DATABASE" class="org.apache.log4j.RollingFileAppender">
    <param name="File" value="/root/OnlineApp/logs/db.log" />
    <param name="MaxFileSize" value="10MB"/>
    <param name="MaxBackupIndex" value="10"/>
    <layout class="org.apache.log4j.PatternLayout">
      <param name="ConversionPattern" value="%d{dd MMM yyyy HH:mm:ss.SSS},%X{deviceId},%p,%m%n" />
    </layout>
  </appender>
  <!-- Loggers -->
  <logger name="OnlineApp" additivity="false">
    <level value="DEBUG" />
    <appender-ref ref="INFO"/>
    <appender-ref ref="ERRORS"/>
    <appender-ref ref="DEBUG"/>
  </logger>
  <logger name="DatabaseLogger" additivity="false">
  <level value="DEBUG" />
  <appender-ref ref="DATABASE"/>
  </logger>

</log4j:configuration>

现在,我尝试在 JBoss AS 7.1.1 Final 中使用具有相同 log4j.xml 文件的相同应用程序。发生的情况是,JBoss 记录到标准输出,而不是记录到我定义的附加程序。

阅读周围的一些问题后,我被告知在 META-INF 下创建一个 jboss-deployment-struct.xml 文件。所以我创建了一个具有以下配置的:

<jboss-deployment-structure>
  <deployment>
    <exclusions>
      <module name="org.apache.log4j"/>
      <module name="org.apache.commons.logging"/>
    </exclusions>
  </deployment>
</jboss-deployment-structure>

但这并没有帮助解决我的问题,因为我在自定义附加程序中仍然没有看到任何日志。

P.S:在我的 WEB-INF/lib 文件夹中,我已确保放置了一个 log4j-1.2.16.jar 文件。

非常感谢任何帮助。

最佳答案

我终于成功了。在 META-INF 文件夹下,创建一个名为 jboss-deployment-struct.xml 的新文件,并确保其中包含以下内容:

<?xml version="1.0" encoding="UTF-8"?>
<jboss-deployment-structure xmlns="urn:jboss:deployment-structure:1.2">
    <deployment>
        <exclusions>
            <module name="org.apache.commons.logging" />
            <module name="org.apache.log4j" />
            <module name="org.jboss.logging" />
            <module name="org.jboss.logging.jul-to-slf4j-stub" />
            <module name="org.jboss.logmanager" />
            <module name="org.jboss.logmanager.log4j" />
            <module name="org.slf4j" />
            <module name="org.slf4j.impl" />
        </exclusions>
    </deployment>
</jboss-deployment-structure>

关于java - JBoss AS 7.1.1 Final 和 Log4j,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19514778/

相关文章:

java.lang.AbstractMethodError : com. ibm.db2.jcc.t4.b.isValid(I)Z 错误

java - JNI : Can not get array length

Java - 无法解析的日期异常

java - Selenium Wire 日志为空

Python 记录器在 atexit 处理程序之前被清理

java - Log4j 和 Logback FileAppender maxFileSize 和 maxBackupIndex

java - 使用 JGit 获取存储库的所有标签

c - syslog.h中的 "0-big number"是什么意思?

java - 动态更改 Log4j 文件名

java - 将 slf4j 与 log4j2 结合使用