1 Sql性能分析目标
分析系统sql运行情况,超阈值sql 记录到单独文件,如执行超过10秒的sql
2 LOG4JDBC使用说明
2.1 jar包
log4jdbc3-1.2beta2.jar、 slf4j-api-1.6.0.jar、slf4j-nop-1.6.1.jar和slf4j-log4j12-1.6.0.ja
2.2 修改JDBC驱动及url
<attribute name="JdbcUrl">jdbc:log4jdbc:postgresql://localhost:5432/postgres</attribute>
<attribute name="DriverClass">net.sf.log4jdbc.DriverSpy</attribute>
2.3 增加log4jdbc.properties
Conf\log4jdbc.properties加入
log4jdbc.dump.sql.addsemicolon=true
log4jdbc.dump.sql.select=true
log4jdbc.dump.sql.insert=true
log4jdbc.dump.sql.update=true
log4jdbc.dump.sql.delete=true
log4jdbc.dump.sql.create=true
#sql运行时间 单位 毫秒
log4jdbc.sqltiming.warn.threshold=100
log4jdbc.sqltiming.error.threshold=10000
log4jdbc.drivers=org.postgresql.Driver
2.3 2.4增加log4jdbc 的日志配置
如:
<appender name="sql-timing-appender"class="org.apache.log4j.RollingFileAppender">
<param name="File"value="${jboss.server.log.dir}/jdbc-sqltiming.log"/>
<param name="Append"value="false"/>
<param name="Threshold" value="info"/>
<paramname="MaxFileSize" value="20MB"/>
<paramname="MaxBackupIndex" value="200"/>
<layoutclass="org.apache.log4j.PatternLayout">
<param name="ConversionPattern"value="%d %-5p [%c] %m%n"/>
</layout>
</appender>
2.5 查看日志文件文件
在 \log\ jdbc-sqltiming.log中
关键字:
[jdbc.sqltiming]
|