【问题标题】:Controlling hibernate logging控制休眠日志
【发布时间】: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


    【解决方案1】:

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

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

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

    【讨论】:

    • 我对此有一些想法,是的,我会尝试您的建议。我知道 %L 问题,我有单独的文件用于生产/开发
    猜你喜欢
    • 2011-08-26
    • 1970-01-01
    • 2011-11-06
    • 1970-01-01
    • 2017-08-24
    • 1970-01-01
    • 2011-08-19
    • 1970-01-01
    相关资源
    最近更新 更多