我的休眠日志配置有一点问题。在我们的应用程序中,我们有两个线程同时尝试在数据库表的每一行上加锁。有时,其中一个线程会尝试锁定已经锁定的行。抛出此错误:
[2/24/12 15:00:34:492 CET] 0000003a JDBCException W org.hibernate.util.JDBCExceptionReporter logExceptions SQL Error: 54, SQLState: 61000
[2/24/12 15:00:34:496 CET] 0000003a JDBCException E org.hibernate.util.JDBCExceptionReporter logExceptions ORA-00054: resource busy and acquire with NOWAIT specified
这些行放在 SystemOut.log 文件中。我正在尝试将它们放在另一个文件中。所以在我的 Log4j 配置文件中,我创建了一个新的 appender,如下所示:
<appender name="JDBCExceptionReporter" class="org.apache.log4j.RollingFileAppender">
<param name="Encoding" value="UTF-8"/>
<param name="File" value="JDBCExceptionReporter.log"/>
<param name="MaxFileSize" value="50000KB"/>
<param name="MaxBackupIndex" value="5"/>
<param name="BufferedIO" value="false"/>
<param name="ImmediateFlush" value="true"/>
<param name="Append" value="true"/>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d, %-5p, %X{ORG_NAME}, %X{USER_NAME}, %c - %m%n"/>
<!-- Use pattern below if it is required to view the log files -->
<!-- using LogFactor5-->
<!--<param name="ConversionPattern" value="[slf5s.start] %d[slf5s.DATE]
%-5p[slf5s.PRIORITY] %X{ORG_NAME} %X{USER_NAME}
[slf5s.NDC] %c[slf5s.CATEGORY] - %m[slf5s.MESSAGE] %n"-->
</layout>
</appender>
最后,我在根元素之前添加了这些记录器:
<logger name="org.hibernate" additivity="false">
<level value="ALL"/>
<appender-ref ref="JDBCExceptionReporter"/>
</logger>
<logger name="org.hibernate.type" additivity="false">
<level value="ALL"/>
<appender-ref ref="JDBCExceptionReporter"/>
</logger>
<logger name="org.hibernate.tool.hbm2ddl" additivity="false">
<level value="ALL"/>
<appender-ref ref="JDBCExceptionReporter"/>
</logger>
<logger name="org.hibernate.pretty" additivity="false">
<level value="ALL"/>
<appender-ref ref="JDBCExceptionReporter"/>
</logger>
<logger name="org.hibernate.cache" additivity="false">
<level value="ALL"/>
<appender-ref ref="JDBCExceptionReporter"/>
</logger>
<logger name="org.hibernate.transaction" additivity="false">
<level value="ALL"/>
<appender-ref ref="JDBCExceptionReporter"/>
</logger>
<logger name="org.hibernate.jdbc" additivity="false">
<level value="ALL"/>
<appender-ref ref="JDBCExceptionReporter"/>
</logger>
<logger name="org.hibernate.hql.ast.AST" additivity="false">
<level value="ALL"/>
<appender-ref ref="JDBCExceptionReporter"/>
</logger>
<logger name="org.hibernate.secure" additivity="false">
<level value="ALL"/>
<appender-ref ref="JDBCExceptionReporter"/>
</logger>
<logger name="org.hibernate.SQL" additivity="false">
<level value="ALL"/>
<appender-ref ref="JDBCExceptionReporter"/>
</logger>
此配置不起作用,这两行始终记录在 SystemOut.log 中,而不是我的 JDBCExceptionReporter.log 中。有人知道我的问题吗?感谢您的帮助。