如何在JBoss EAP 6.3中记录hibernate 4生成的SQL语句

时间:2015-03-15 12:00:00

标签: log4j jboss-eap-6 hibernate-4.x

我目前正在开发一个小型的Web应用程序,我部署在JBoss EAP 6.3.0.GA(版本7.4.0.Final-redhat-19)上。

此应用程序使用hibernate作为其JPA提供程序(hibernate版本4.2.14.SP1-redhat-1),并且它还在webapp和数据层之间使用EJB。)

我已成功配置我的应用程序,以通过log4j在特定文件中记录其进程。

我还成功配置了hibernate,将语句的参数记录到同一个文件中。

使用的log4j版本是1.2.16。

我的问题是,当我通过webapp调用我的DAO时,hibernate生成的SQL语句永远不会登录到文件,如果通过main方法远程调用业务EJB,那些语句将记录到server.log文件中

我需要这些日志,因为数据源上的间谍提供的日志不适合我的情况(我必须在应用程序的基础上而不是整个服务器上记录hibernate的东西)。

你能说我在我的申请中错误配置了什么吗? 这是我目前存储我的应用程序的github的链接:https://github.com/lionelh/jboss-testing

感谢您的帮助。

这也是我的应用程序部署的log4j.properties:

#
# ROOT LOGGER
#
log4j.rootLogger=DEBUG

log4j.appender.applog=org.apache.log4j.DailyRollingFileAppender
log4j.appender.applog.File=../standalone/log/jbosstesting.log
log4j.appender.applog.DatePattern='-'yyyy-MM-dd
log4j.appender.applog.layout=org.apache.log4j.PatternLayout
log4j.appender.applog.layout.ConversionPattern=%5p *** %d{dd/MM/yyyy HH:mm:ss,SSS} *** (%C:%L) *** %m%n

#
# LOGGERS
#
log4j.logger.be.lionelh.jbosstesting=DEBUG, applog
log4j.logger.org.hibernate.SQL=DEBUG, applog
log4j.logger.org.hibernate.type.descriptor.sql.BasicBinder=trace, applog
log4j.logger.org.hibernate.type.descriptor.sql.BasicEXtractor=trace, applog

以下是JUnit测试期间生成的日志文件的内容(这是部署webapp时我想要的):

DEBUG *** 14/03/2015 16:30:36,996 *** [main] (UserDaoImpl.java:41) *** In findById
DEBUG *** 14/03/2015 16:30:36,999 *** [main] (SqlStatementLogger.java:104)    *** select user0_.US_ID as US_ID1_0_0_, user0_.US_CREATION_DATE as US_CREAT2_0_0_, user0_.US_LANGUAGE as US_LANGU3_0_0_, user0_.US_LAST_UPDATE_DATE as US_LAST_4_0_0_, user0_.US_LOGIN as US_LOGIN5_0_0_ from phone_user user0_ where user0_.US_ID=?
TRACE *** 14/03/2015 16:30:37,003 *** [main] (BasicBinder.java:84) *** binding parameter [1] as [BIGINT] - 1
TRACE *** 14/03/2015 16:30:37,005 *** [main] (BasicExtractor.java:74) *** Found [2015-02-14 21:22:55.0] as column [US_CREAT2_0_0_]
TRACE *** 14/03/2015 16:30:37,005 *** [main] (BasicExtractor.java:74) *** Found [F] as column [US_LANGU3_0_0_]
TRACE *** 14/03/2015 16:30:37,006 *** [main] (BasicExtractor.java:74) *** Found [2015-02-14 21:22:55.0] as column [US_LAST_4_0_0_]
TRACE *** 14/03/2015 16:30:37,006 *** [main] (BasicExtractor.java:74) *** Found [lh] as column [US_LOGIN5_0_0_]

以下是将应用程序部署到JBoss时的日志内容(SQL staement缺失:

DEBUG *** 14/03/2015 19:54:30,827 *** (be.lionelh.jbosstesting.web.UserBean:69) *** In login()
DEBUG *** 14/03/2015 19:54:30,923 *** (be.lionelh.jbosstesting.data.ejb.JBossTestingBean:35) *** In createUser(UserDto)
DEBUG *** 14/03/2015 19:54:30,924 *** (be.lionelh.jbosstesting.data.domain.dao.impl.UserDaoImpl:28) *** In create(User)
TRACE *** 14/03/2015 19:54:31,146 *** (org.hibernate.type.descriptor.sql.BasicBinder:84) *** binding parameter [1] as [TIMESTAMP] - Sat Mar 14 19:54:31 CET 2015
TRACE *** 14/03/2015 19:54:31,161 *** (org.hibernate.type.descriptor.sql.BasicBinder:84) *** binding parameter [2] as [VARCHAR] - F
TRACE *** 14/03/2015 19:54:31,164 *** (org.hibernate.type.descriptor.sql.BasicBinder:84) *** binding parameter [3] as [TIMESTAMP] - Sat Mar 14 19:54:31 CET 2015
TRACE *** 14/03/2015 19:54:31,165 *** (org.hibernate.type.descriptor.sql.BasicBinder:84) *** binding parameter [4] as [VARCHAR] - vp
DEBUG *** 14/03/2015 19:54:31,286 *** (be.lionelh.jbosstesting.data.ejb.JBossTestingBean:42) *** In findAllUsers()
DEBUG *** 14/03/2015 19:54:31,287 *** (be.lionelh.jbosstesting.data.domain.dao.impl.UserDaoImpl:35) *** In findAll()

1 个答案:

答案 0 :(得分:0)

问题是Hibernate将使用服务器而不是您的应用程序的日志配置。鉴于您的示例配置,虽然配置日志记录子系统可以很容易地执行此操作。

您可以将以下CLI命令放入文件中,然后通过$JBOSS_HOME/bin/jboss-cli.sh -c --file="path/to/file.cli"

运行它们
batch

/subsystem=logging/pattern-formatter=applog-formatter:add(pattern="%5p *** %d{dd/MM/yyyy HH:mm:ss,SSS} *** (%C:%L) *** %m%n")
/subsystem=logging/periodic-rotating-file-handler=applog:add(append=true,autoflush=true,named-formatter=applog-formatter,suffix="'-'yyyy-MM-dd",file={relative-to="jboss.server.log.dir",path="jbosstesting.log"})
/subsystem=logging/logger=be.lionelh.jbosstesting:add(level=DEBUG,handlers=[applog])
/subsystem=logging/logger=org.hibernate.SQL:add(level=DEBUG,handlers=[applog],use-parent-handlers=false)
/subsystem=logging/logger=org.hibernate.type.descriptor.sql.BasicBinder:add(level=TRACE,handlers=[applog],use-parent-handlers=false)
/subsystem=logging/logger=org.hibernate.type.descriptor.sql.BasicEXtractor:add(level=TRACE,handlers=[applog],use-parent-handlers=false)

run-batch

您还需要删除log4j.properties,以便服务器不会尝试根据这些设置配置日志管理器。

您也可以将脚本与jboss-as-maven-plugin一起使用。