以前在项目中使用iBatis,最痛苦的莫过于看到的sql为PreparedStatment输出的一串串"?"的东东。当时也没多想,认为自己写的pstmt就是这么个模样,难不成人家还会自动照顾到你?
这几天才“忽然”发现P6Spy这么个好东西,拿来一试,果真不错。
一般使用步骤,言简意赅吧:
1、下载:
p6spy: http://www.p6spy.com
SQL Profile: http://www.jahia.net/jahia/page597.html
2、安装:
很简单,把p6spy-1.x.jar和sqlprofiler.jar拷贝到自己的应用的WEB-INF/lib下即可。
3、配置:
1)修改你 原有 JDBC Driver为:com.p6spy.engine.spy.P6SpyDriver,如果你用了连接池,一回事,把driver换掉;
2)修改 spy.properties 中的 realdriver 值为 原有 的JDBC Driver,比如我的是:realdriver=com.ibm.db2.jcc.DB2Driver
3) 还有,注意把appender设置正确:
#The following are for log4j logging only
#log4j.appender.STDOUT=org.apache.log4j.ConsoleAppender
#log4j.appender.STDOUT.layout=org.apache.log4j.PatternLayout
#log4j.appender.STDOUT.layout.ConversionPattern=p6spy - %m%n
log4j.appender.SQLPROFILER_CLIENT=org.apache.log4j.net.SocketAppender
log4j.appender.SQLPROFILER_CLIENT.RemoteHost=localhost
log4j.appender.SQLPROFILER_CLIENT.Port=4445
log4j.appender.SQLPROFILER_CLIENT.LocationInfo=true
#log4j.logger.p6spy=INFO,STDOUT
log4j.logger.p6spy=DEBUG, SQLPROFILER_CLIENT
4、一般使用:
1)在DOS命令行切换到刚才的WEB-INF/lib目录下,运行:java -jar sqlprofiler.jar,即可启动SQL Profiler的GUI界面;
2)正常启动服务,允许web server,即可在SQL Profiler的GUI界面看到所有的JDBC操作。
5、高级应用SQL Profiler:
1)可以生成SQL执行情况报表:点击“pause”按钮,即可产生profiler result;
2)很cool的是,点击最左边的按钮,可以根据整个运行情况生成数据库索引的创建脚本,我们可以根据这些脚本生成自己的数据库索引,数据库tuning的工作是不是变得越来越简单or傻瓜了呢?呵呵。
3)其他的包括图形分析报表,自己挖掘吧;
4)如果用loadRunner、web stress tool等压力测试工具run一把,那么这个报表和索引创建建议就更加逼真和有效了。
FAQ:
1)开始配置好后,着急想看效果,结果老是发现connection refused的错误,郁闷了半天,找了半天资料才发现必须先启动SQL Profiler(参考步骤4-1),再启动应用才是正确的步骤。why?好奇人多了,简单的答案就是SQL Profiler把JDBC WRAP了一下,此时会先行与数据库建立一个socket连接,否则这些SQL怎么来,就是这么回事。