【发布时间】:2010-01-08 16:19:02
【问题描述】:
我使用休眠在 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);
也没有成功...
【问题讨论】:
标签: java hibernate logging log4j