使用P6Spy监控你的Spring boot数据库操作
引言
最近换了号称最快的HikariDataSource
,由于没有了SQL
监控,加之于Mybaits
默认输出日志之拙计。遂用此物,与之相仿还有log4jdbc
,比较活跃度后选择了P6Spy
。
版本
- P6Sspy: 3.7
- Gradle: 4.10
- Spring Boot: 2.0.4
步骤
具体步骤比较简单,这里说下简单原理。P6Spy
通过劫持JDBC
驱动,在调用实际JDBC
驱动前拦截调用的目标语,达到SQL
语句日志记录的目的。
它包括P6Log
和P6Outage
两个模块。
- P6Log 用来拦截和记录任务应用程序的 JDBC 语句
- P6Outage 专门用来检测和记录超过配置条件里时间的 SQL 语句
应用P6Spy
只需要
- 1.替换你的
JDBC Driver
为com.p6spy.engine.spy.P6SpyDriver
- 2.修改
JDBC Url
为jdbc:p6spy:xxxx
- 3.配置
spy.properties
1.修改application.yml
文件,替换jdbc driver
和url
1 2 3 4 5 6 7 8
| # 数据源 spring: datasource: type: com.zaxxer.hikari.HikariDataSource url: jdbc:p6spy:mysql: username: ... password: ... driver-class-name: com.p6spy.engine.spy.P6SpyDriver
|
2.配置spy.properties
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
| module.log=com.p6spy.engine.logging.P6LogFactory,com.p6spy.engine.outage.P6OutageFactory
logMessageFormat=org.pkaq.core.log.P6SpyLogger
appender=com.p6spy.engine.spy.appender.Slf4JLogger
excludecategories=info,debug,result,batc,resultset
deregisterdrivers=true
dateformat=yyyy-MM-dd HH:mm:ss
driverlist=com.mysql.jdbc.Driver
outagedetection=true
outagedetectioninterval=2
|
3.自定义日志打印 , 实现MessageFormattingStrategy
接口即可
1 2 3 4 5 6 7 8 9
| public class P6SpyLogger implements MessageFormattingStrategy {
@Override public String formatMessage(int connectionId, String now, long elapsed, String category, String prepared, String sql) { return !"".equals(sql.trim()) ? "[ " + LocalDateTime.now() + " ] --- | took " + elapsed + "ms | " + category + " | connection " + connectionId + "\n " + sql + ";" : ""; } }
|
附录: spy.properties
详细说明
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108
|
|