Java呼叫鏈跟蹤關鍵技術(四)SQL監控

Java極客發表於2019-08-05

一、SQL監控一般思路

Java中SQL監控一般通過代理模式實現,如下:

Java呼叫鏈跟蹤關鍵技術(四)SQL監控

  1. 右邊是JDBC介面類。
  2. 左邊是代理類,代理類需要實現JDBC介面,同時持有介面類的物件例項。
  3. 資料庫連線工廠原來是獲得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的配置

  1. jdbc.driver 替換為 com.p6spy.engine.spy.P6SpyDriver
spring.datasource.driver-class-name=com.p6spy.engine.spy.P6SpyDriver
複製程式碼
  1. jdbc.url 替換為 jdbc:p6spy:mysql:/xxx
spring.datasource.url=jdbc:p6spy:mysql://XXX
複製程式碼

XXX部分自行替換。至此,可以監控到SQL語句了。

p6spy專案地址: github.com/p6spy/p6spy

end.


微信公眾號:

Java呼叫鏈跟蹤關鍵技術(四)SQL監控


加入《Java棧實戰營》知識星球,參與討論,更多實戰程式碼分享,不就是幾斤蘋果,幾個榮耀道具的事嗎!

t.zsxq.com/RNzfi2j

Java呼叫鏈跟蹤關鍵技術(四)SQL監控

相關文章