一、SQL監控一般思路
Java中SQL監控一般通過代理模式實現,如下:
- 右邊是JDBC介面類。
- 左邊是代理類,代理類需要實現JDBC介面,同時持有介面類的物件例項。
- 資料庫連線工廠原來是獲得JDBC介面類後繼續操作,改為獲取代理類去操作,因代理類實現了JDBC介面,所以對呼叫方來說無感知,仍然以原有的方式呼叫。
因此,最差情況是自行實現代理類,難度不大,只是所有介面方法都要實現一遍,純體力活。
二、開源JAVA SQL監控工具p6spy
p6spy是一款Java開源監控工具,出來已經有十幾年,應該算很成熟了,下面介紹p6spy的使用。
1.引入maven依賴,當前最新版本3.8.3
<dependency>
<groupId>p6spy</groupId>
<artifactId>p6spy</artifactId>
<version>3.8.3</version>
</dependency>
複製程式碼
2.實現監控類 只要實現如下的介面類則可,logSQL方法已經可以獲取必要的資訊,實現類中直接使用就好。
package com.p6spy.engine.spy.appender;
import com.p6spy.engine.logging.Category;
public interface P6Logger {
/**
* Logs the {@code SQL}.
*
* @param connectionId
* connection identifier.
* @param now
* current time.
* @param elapsed
* @param category
* the category to be used for logging.
* @param prepared
* the prepared statement to be logged.
* @param sql
* the {@code SQL} to be logged.
* @param url
* the database url where the sql statement executed
*/
public void logSQL(int connectionId, String now, long elapsed,
Category category, String prepared, String sql, String url);
/**
* Logs the stacktrace of the exception.
*
* @param e
* exception holding the stacktrace to be logged.
*/
public void logException(Exception e);
/**
* Logs the text.
*
* @param text
* to be logged
*/
public void logText(String text);
/**
* @param category
* the category to be evaluated.
* @return {@code true} if category is enabled. Otherwise returns
* {@code false}
*/
public boolean isCategoryEnabled(Category category);
}
複製程式碼
3.配置 將p6spy專案下p6spy/src/main/assembly/individualFiles/spy.properties檔案放到resources目錄下或者classpath中,找到appender將類名修改為你自己的實現類,並去掉#:
#appender=com.p6spy.engine.spy.appender.FileLogger
複製程式碼
其他所有配置都不用修改就可以監控到SQL。
4.修改Spring的配置
- jdbc.driver 替換為 com.p6spy.engine.spy.P6SpyDriver
spring.datasource.driver-class-name=com.p6spy.engine.spy.P6SpyDriver
複製程式碼
- jdbc.url 替換為 jdbc:p6spy:mysql:/xxx
spring.datasource.url=jdbc:p6spy:mysql://XXX
複製程式碼
XXX部分自行替換。至此,可以監控到SQL語句了。
p6spy專案地址: github.com/p6spy/p6spy
end.
微信公眾號:
加入《Java棧實戰營》知識星球,參與討論,更多實戰程式碼分享,不就是幾斤蘋果,幾個榮耀道具的事嗎!