一、p6spy核心作用
-
完整SQL捕获:输出带实际参数的SQL语句,无需手动拼接
-
性能分析:精确记录每条SQL执行耗时
-
慢查询检测:支持阈值配置自动标记慢SQL(如 >2s)
-
ORM调试:验证MyBatis等框架生成的SQL
二、集成步骤
-
添加依赖(关键依赖):
<dependency>
<groupId>p6spy</groupId>
<artifactId>p6spy</artifactId>
<version>3.9.1</version>
</dependency>
<!-- MyBatis Plus需额外添加 -->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-p6spy</artifactId>
</dependency>
-
配置数据源(关键改动):
spring:
datasource:
driver-class-name: com.p6spy.engine.spy.P6SpyDriver # 替换驱动
url: jdbc:p6spy:mysql://localhost:3306/db # URL添加p6spy前缀
-
创建日志格式化类(可选增强):
public class CustomP6SpyLogger implements MessageFormattingStrategy {
@Override
public String formatMessage(...) {
// 示例:添加ANSI颜色/格式化日期参数
return String.format("\u001B[33m%s | 耗时:%dms | SQL:\u001B[32m%s\u001B[0m",
now, elapsed, formattedSql);
}
}
-
配置spy.properties(核心配置):
# 日志输出方式
appender=com.p6spy.engine.spy.appender.StdoutLogger
# 自定义格式化类
logMessageFormat=com.example.CustomP6SpyLogger
# 慢SQL检测(2秒阈值)
outagedetection=true
outagedetectioninterval=2
# 排除无关日志
excludecategories=info,debug,resultset
三、注意事项
-
版本兼容:MySQL 8.x需使用p6spy 3.9.x
- 性能损耗:增加约5%-10%开销,生产环境建议:
-
关闭常规监控
-
仅启用慢查询检测
-
-
文件位置:
spy.properties
必须放在src/main/resources
-
日志优化:通过
excludecategories
过滤非SQL日志
四、效果演示
控制台输出示例:
2023-05-01 12:30:45 | 耗时: 148ms | SQL: SELECT * FROM user WHERE create_time > '2023-01-01 00:00:00'
可直接拷贝SQL到数据库客户端执行
五、总结
p6spy解决了开发中的两大痛点:
-
直观获取完整SQL:摆脱参数占位符拼接
-
精准定位慢查询:通过耗时监控优化数据库性能 建议在开发/测试环境启用,生产环境按需使用慢查询监控功能。