org.jboss.logging.Logger而不是根据运行时环境打印在日志中的类名

时间:2015-12-03 10:42:04

标签: logging jboss log4j slf4j

我有一个在JBoss 5.1上运行的大应用程序,并通过slf4j使用log4j。当我在本地docker容器中测试时,我可以在日志中看到通常的package.class名称:

03 Dec 15 09:45:39, DEBUG  my.fancy.app.filters.TicketValidationFilter:doFilter:30 Ticket was verified with data: uniqueID=gfd, idnumber=sdf, mid=11246986.
03 Dec 15 09:45:39, DEBUG  my.fancy.app.MyServlet:doGet:30 Request for secret data with uniqueId=gfd
03 Dec 15 09:45:39, WARN   my.fancy.app.MyServlet:doGet:36 Could not retrieve SecretData with uniqueId=gfd

然而,当我将相同的代码部署到开发环境(可能不那么干净......)时,我得到:

03 dec 15 10:45:22, DEBUG  org.jboss.logging.Logger:debug:228 Ticket was verified with data: uniqueID=sdg, idnumber=sdf, mid=11738149.
03 dec 15 10:45:22, DEBUG  org.jboss.logging.Logger:debug:228 Request for secret data with uniqueId=sdg
03 dec 15 10:45:22, WARN   org.jboss.logging.Logger:warn:352 Could not retrieve SecretData with uniqueId=sdg

我在两种环境中都比较了jboss-log4j.xml,它们是相同的。我还检查了启动标志,看看是否设置了日志记录提供程序,但它们都不在这些环境中。

我下一步该去哪儿看?

更新

我还应该提一下,之前我们一直在使用log4j,所以我们仍然有直接的log4j导入和实例化分散在这里和那里。奇怪的是,那些使用log4j记录的条目在所有环境中都能正确显示,而那些只能在某些环境中使用slf4j的条目。这应该是一个线索,即在违规环境中没有真正正确配置slf4j。问题是我应该在哪里修复它?

更新2

这是appender配置:

<appender name="MYAPP_FILE" class="org.jboss.logging.appender.DailyRollingFileAppender"> <param name="File" value="${jboss.server.log.dir}/myapp.log" /> <param name="Append" value="true" /> <param name="DatePattern" value="'.'yyyy-MM-dd"/> <layout class="org.apache.log4j.PatternLayout"> <param name="ConversionPattern" value="%d{dd MMM yyy HH:mm:ss}, %-6p %C:%M:%L %m %n" /> </layout> </appender>

记录器声明:

import org.slf4j.Logger; import org.slf4j.LoggerFactory; ... public class MyServlet extends HttpServlet { private Logger log = LoggerFactory.getLogger(MyServlet.class.getName()); ... log.debug("Request for secret data with uniqueId={}", secretDataVO.getUniqueId()); ... }

在pom.xml中我有:

<dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>1.2.14</version> <scope>provided</scope> </dependency> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-api</artifactId> <version>1.5.10</version> <scope>provided</scope> </dependency> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-log4j12</artifactId> <version>1.5.10</version> <scope>provided</scope> </dependency>

依赖于log4j是因为在应用程序代码的其他地方我们仍然直接使用log4j。 slf4j-log4j12被标记为提供,因为它是由同一个jboss实例中的另一个工件加载的。

更新3

启动jboss时显示错误:

2015-12-07 16:16:50,127 ERROR [STDERR] log4j:ERROR A "org.jboss.logging.appender.FileAppender" object is not assignable to a "org.apache.log4j.Appender" variable. 2015-12-07 16:16:50,127 ERROR [STDERR] log4j:ERROR The class "org.apache.log4j.Appender" was loaded by 2015-12-07 16:16:50,127 ERROR [STDERR] log4j:ERROR [BaseClassLoader@14a33aa{vfszip:/my-jboss-root/jboss/server/default/deploy/fancyApp.ear/fancyApp-web.war/}] whereas object of type 2015-12-07 16:16:50,127 ERROR [STDERR] log4j:ERROR "org.jboss.logging.appender.FileAppender" was loaded by [org.jboss.bootstrap.NoAnnotationURLClassLoader@15b0afd]. 2015-12-07 16:16:50,127 ERROR [STDERR] log4j:ERROR Could not instantiate appender named "FILE".

fancyApp-web.war是加载slf4j-log4j12的地方。我之前看到过这个错误,但没有提到它,因为它出现在本地(docker)和开发环境中(即使是在这个问题上也是如此......)

2 个答案:

答案 0 :(得分:0)

尝试使用LoggerFactory.getLogger(MyServlet.class),并在此处注明:http://www.slf4j.org/api/org/slf4j/LoggerFactory.html#getLogger%28java.lang.Class%29

  

如果clazz参数与调用者名称不同,则为   由SLF4J内部计算,记录器名称不匹配警告将是   打印但仅限于slf4j.detectLoggerNameMismatch系统属性   设置为true。默认情况下,此属性未设置且没有警告   即使记录器名称不匹配,也会打印出来。

还在log4j.xml中设置debug="true"并观察log4j初始化。

答案 1 :(得分:0)

将生产环境的调试器设置为true,并在配置文件中设置。