控制休眠日志记录

时间:2010-01-08 16:19:03

标签: java hibernate logging log4j

我使用hibernate在jboss容器中运行了一个应用程序。但是我遇到了hibernate正在进行的日志记录问题。我在Hibernate初始化时收到这些启动消息:

2010-01-08 17:23:42,017 INFO  [Configuration:1403] - Configuration resource: /hibernate.cfg.xml
2010-01-08 17:23:42,070 INFO  [Configuration:1541] - Configured SessionFactory: null

等等。但是我想摆脱它们,因为它是无用的信息。我在log4j.properties中有以下配置:

log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d %-5p [%c{1}:%L] - %m%n

log4j.rootCategory = error, stdout

# Hibernate
log4j.logger.org.hibernate=error
log4j.logger.org.hibernate.tool.hbm2ddl=fatal

正如您所看到的,日志记录与我的 ConversionPattern 中指定的格式相匹配。但是我仍然收到INFO消息。我也在使用Asterisk-Java API

# Asterisk java
log4j.logger.org.asteriskjava=error

这确实有效,因为我只会收到错误:

2010-01-08 17:31:46,948 ERROR [AgiConnectionHandler:156] - AgiException running AgiScript com.**** on Asterisk-Java DaemonPool-1-thread-2 org.asteriskjava.fastagi.AgiException: Number is on blacklist

所以我现在有点困惑。

更新

使用

运行容器时
-Dlog4j.debug

我明白了:

log4j: Reading configuration from URL jar:file:*******.jar!/log4j.properties
log4j: Parsing for [root] with value=[error, stdout].
log4j: Level token is [error].
log4j: Category root set to ERROR
log4j: Parsing appender named "stdout".
log4j: Parsing layout options for "stdout".
log4j: Setting property [conversionPattern] to [%d %-5p [%c{1}:%L] - %m%n].
log4j: End of parsing for "stdout".
log4j: Parsed "stdout" options.
log4j: Parsing for [org.hibernate.tool.hbm2ddl] with value=[error].
log4j: Level token is [error].
log4j: Category org.hibernate.tool.hbm2ddl set to ERROR
log4j: Handling log4j.additivity.org.hibernate.tool.hbm2ddl=[null]
log4j: Parsing for [org.hibernate] with value=[fatal].
log4j: Level token is [fatal].
log4j: Category org.hibernate set to FATAL
log4j: Handling log4j.additivity.org.hibernate=[null]
log4j: Parsing for [org.asteriskjava] with value=[error].
log4j: Level token is [error].
log4j: Category org.asteriskjava set to ERROR
log4j: Handling log4j.additivity.org.asteriskjava=[null]
log4j: Finished configuring.

没有任何其他文件被加载。所以我想知道为什么它不起作用。在创建会话工厂之前,我还尝试了以下操作:

Logger.getLogger("org.hibernate").setLevel(Level.ERROR);

也没有成功......

1 个答案:

答案 0 :(得分:1)

听起来像某个地方的另一个日志记录配置可能会覆盖你的。您可能希望尝试将系统变量-Dlog4j.debug添加到容器的启动路径中,以便log4j将打印出它的调试信息,这将告诉您确切地使用哪个文件来配置自身。可能正在使用类路径上的另一个文件而不是您的文件。

此外,您真的不应该在任何类型的生产环境中使用%L - the Javadoc explicitly warns against this

  

%L:
  用于输出发出日志记录请求的行号   警告生成来电者位置信息非常慢。除非执行速度不是问题,否则应该避免使用它。