资讯专栏INFORMATION COLUMN

Java调用链跟踪关键技术(四)SQL监控

?xiaoxiao, / 1552人阅读

摘要:一监控一般思路中监控一般通过代理模式实现,如下右边是接口类。配置将项目下文件放到目录下或者中,找到将类名修改为你自己的实现类,并去掉其他所有配置都不用修改就可以监控到。至此,可以监控到语句了。

一、SQL监控一般思路

Java中SQL监控一般通过代理模式实现,如下:

右边是JDBC接口类。

左边是代理类,代理类需要实现JDBC接口,同时持有接口类的对象实例。

数据库连接工厂原来是获得JDBC接口类后继续操作,改为获取代理类去操作,因代理类实现了JDBC接口,所以对调用方来说无感知,仍然以原有的方式调用。

因此,最差情况是自行实现代理类,难度不大,只是所有接口方法都要实现一遍,纯体力活。

二、开源JAVA SQL监控工具p6spy

p6spy是一款Java开源监控工具,出来已经有十几年,应该算很成熟了,下面介绍p6spy的使用。
1.引入maven依赖,当前最新版本3.8.3


  p6spy
  p6spy
  3.8.3

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

2) jdbc.url 替换为 jdbc:p6spy:mysql:/xxx

spring.datasource.url=jdbc:p6spy:mysql://XXX

XXX部分自行替换。至此,可以监控到SQL语句了。

p6spy项目地址: https://github.com/p6spy/p6spy

end.

加入《Java栈实战营》知识星球,参与讨论,更多实战代码分享,不就是几斤苹果,几个荣耀道具的事吗!

https://t.zsxq.com/RNzfi2j

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/75810.html

相关文章

  • Java调用跟踪关键技术(一)总体介绍

    摘要:微服务中调用栈的获取,使用的开发者会很自然想到用来拦截,但是拦截同一个类的多个方法之间的调用很不方便,有侵入性,因此并不适合。调用栈的跟踪也提供了这个能力,可以获得当前方法的调用栈信息。 一、调用链跟踪的作用 调用链跟踪包括 1.前端到后端的调用链 2.单个服务内部方法之间的调用链 3.微服务之间的调用链 4.应用服务和数据库之间的调用链 5.应用服务和第三方服务中...

    gaara 评论0 收藏0
  • UAVStack的慢SQL数据库监控功能及其实现

    摘要:页面展示的统计追踪等信息则通过的接口获取四功能展示数据库监控目前已实现的功能有分类统计数据库连接池监控慢耗时分布统计慢统计慢追踪以及调用链日志关联功能。 作者: 王林林 出处:UAVStack智能运维 来源:宜信技术学院技术沙龙001期|AI中台:一种敏捷的智能业务支持方案|宜信技术沙龙 3月28日晚8点线上直播,点击报名 UAVStack是一个全维监控与应用运维平台。UAV.Mon...

    luodongseu 评论0 收藏0
  • Java调用跟踪关键技术(三)线程变量

    摘要:除了以上级别的成员变量共享,在调用链跟踪时要能识别不同分层下的多个类实例的调用是同一个请求,而这个请求的调用都在一个独立线程内完成,此时就要用到线程级变量共享。 一、Java类成员作用域 JAVA类成员作用域参考下图: showImg(https://segmentfault.com/img/bVbvWlh?w=1695&h=925); Java虚拟机级作用域,通过在类成员变量前加...

    ThreeWords 评论0 收藏0
  • Java调用跟踪关键技术(五)获取调用

    摘要:一调用栈调用链监控仅仅获取调用顺序是不够的,如前所描述左边只体现了顺序,右边体现了顺序和调用栈信息。二获取调用栈在中获取调用栈的方法如下代码示例输出结果可以看到第个栈是调用的方法。 一、调用栈 调用链监控仅仅获取调用顺序是不够的,如前所描述: showImg(https://segmentfault.com/img/bVbvV9H?w=500&h=230);左边只体现了顺序,右边体现...

    VPointer 评论0 收藏0

发表评论

0条评论

?xiaoxiao,

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<