我使用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);
也没有成功......
答案 0 :(得分:1)
听起来像某个地方的另一个日志记录配置可能会覆盖你的。您可能希望尝试将系统变量-Dlog4j.debug
添加到容器的启动路径中,以便log4j将打印出它的调试信息,这将告诉您确切地使用哪个文件来配置自身。可能正在使用类路径上的另一个文件而不是您的文件。
此外,您真的不应该在任何类型的生产环境中使用%L - the Javadoc explicitly warns against this:
%L:
用于输出发出日志记录请求的行号 警告生成来电者位置信息非常慢。除非执行速度不是问题,否则应该避免使用它。