iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >SpringBoot如何集成P6Spy实现SQL日志
  • 569
分享到

SpringBoot如何集成P6Spy实现SQL日志

2023-07-06 12:07:09 569人浏览 独家记忆
摘要

本篇内容介绍了“SpringBoot如何集成P6Spy实现sql日志”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!P6Spy简介P6Spy是

本篇内容介绍了“SpringBoot如何集成P6Spy实现sql日志”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

P6Spy简介

P6Spy是一个可以用来在应用程序中拦截和修改数据操作语句的开源框架

通过P6Spy可以对SQL语句进行拦截,相当于一个SQL语句的记录器,这样我们可以用它来作相关的分析,比如性能分析。

应用场景

pom
<dependencies>        <dependency>            <groupId>org.springframework.boot</groupId>            <artifactId>spring-boot-starter</artifactId>        </dependency>        <dependency>            <groupId>org.springframework.boot</groupId>            <artifactId>spring-boot-starter-test</artifactId>            <scope>test</scope>        </dependency>        <dependency>            <groupId>com.alibaba</groupId>            <artifactId>druid-spring-boot-starter</artifactId>            <version>1.1.20</version>        </dependency>        <dependency>            <groupId>mysql</groupId>            <artifactId>Mysql-connector-java</artifactId>        </dependency>        <dependency>            <groupId>com.baomidou</groupId>            <artifactId>mybatis-plus-boot-starter</artifactId>            <version>3.1.1</version>        </dependency>        <dependency>            <groupId>org.projectlombok</groupId>            <artifactId>lombok</artifactId>        </dependency>        <dependency>            <groupId>p6spy</groupId>            <artifactId>p6spy</artifactId>            <version>3.8.2</version>        </dependency>        <dependency>            <groupId>com.alibaba</groupId>            <artifactId>fastJSON</artifactId>            <version>1.2.83</version>        </dependency>    </dependencies>
application.yml

spring:
 datasource:
   driver-class-name: com.mysql.cj.jdbc.Driver
   #driver-class-name: com.p6spy.engine.spy.P6SpyDriver
   type: com.alibaba.druid.pool.DruidDataSource
   url: jdbc:mysql://localhost:3306/course_db?serverTimezone=GMT%2B8
   # url: jdbc:p6spy:mysql://localhost:3306/course_db?serverTimezone=GMT%2B8
   username: root
   passWord: root

# 打开mybatis-plus的sql日志输出
mybatis-plus:
 configuration:
   log-impl: org.apache.ibatis.logging.stdout.StdOutImpl

entity
@Data@NoArgsConstructor@AllArgsConstructor@TableName("course_1")public class Course {    @TableField("cid")    private Long cId;    private String cName;    private Integer userId;    private String cStatus;}
Mapper
public interface CourseMapper extends BaseMapper<Course> {}
启动类
@SpringBootApplication@MapperScan(basePackages = "cn.zysheep.mapper")public class ShardingjdbcdemoApplication {    public static void main(String[] args) {        SpringApplication.run(ShardingjdbcdemoApplication.class, args);    }}
测试
@SpringBootTest@Slf4jclass ShardingjdbcdemoApplicationTests {    @Autowired    private CourseMapper courseMapper;    @SneakyThrows    @Test    void findCourse() {        courseMapper.selectList(null).forEach(System.out::println);    }}

mybatis-plus也可以打印输出的sql日志,但是不是我们想要的效果,如何来控制想要的sql日志输出,可以使用P6Spy开源产品。

SpringBoot如何集成P6Spy实现SQL日志

P6Spy入门使用

spy.properties

resources目录添加配置文件,类似log4j.xml,记录配置信息

module.log=com.p6spy.engine.logging.P6LogFactory,com.p6spy.engine.outage.P6OutageFactory
# sql日志打印输出
# 1、logMessageFORMat=com.p6spy.engine.spy.appender.SingleLineFormat
# 2、logMessageFormat=com.p6spy.engine.spy.appender.CustomLineFormat
# customLogMessageFormat=%(currentTime) | SQL use time: %(executionTime) ms | connect info: %(cateGory)-%(connectionId) | execute sql: %(sql)
# 3、自定义日志打印(全限定类名)
logMessageFormat=cn.zysheep.config.P6SPYConfig
# 使用日志系统记录sql
appender=com.p6spy.engine.spy.appender.Slf4JLogger
## 配置记录Log例外
excludecategories=info,debug,result,batc,resultset
# 设置使用p6spy driver来做代理
dereGISterdrivers=true
# 日期格式
dateformat=yyyy-MM-dd HH:mm:ss
# 实际驱动
driverlist=com.mysql.cj.jdbc.Driver
# 是否开启慢SQL记录
outagedetection=true
# 慢SQL记录标准 秒
outagedetectioninterval=2

P6Spy有内置的SQL输出格式,如上配置文件。这里我们使用自定义SQL日志打印

P6SPYConfig
public class P6SPYConfig  implements MessageFormattingStrategy {    @Override    public String formatMessage(int connectionId, String now, long elapsed, String category, String prepared, String sql, String url) {        Map<String, Object> message = new LinkedHashMap<>(8);        String newPrepared = prepared.replace("   ", "").replace("\n", " ");        message.put("prepared", newPrepared);        String newSql = sql.replace("   ", "").replace("\n", " ");        message.put("sql", newSql);        return jsONObject.toJSONString(message, true);    }}
application.yml

spring:
 datasource:
   # driver-class-name: com.mysql.cj.jdbc.Driver
   driver-class-name: com.p6spy.engine.spy.P6SpyDriver
   type: com.alibaba.druid.pool.DruidDataSource
   #  url: jdbc:mysql://localhost:3306/course_db?serverTimezone=GMT%2B8
   url: jdbc:p6spy:mysql://localhost:3306/course_db?serverTimezone=GMT%2B8
   username: root
   password: root

# 打开mybatis-plus的sql日志输出
mybatis-plus:
 configuration:
   log-impl: org.apache.ibatis.logging.stdout.StdOutImpl

测试类不变

SpringBoot如何集成P6Spy实现SQL日志

“SpringBoot如何集成P6Spy实现SQL日志”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

--结束END--

本文标题: SpringBoot如何集成P6Spy实现SQL日志

本文链接: https://www.lsjlt.com/news/358137.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • SpringBoot如何集成P6Spy实现SQL日志
    本篇内容介绍了“SpringBoot如何集成P6Spy实现SQL日志”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!P6Spy简介P6Spy是...
    99+
    2023-07-06
  • SpringBoot怎么集成P6Spy实现SQL日志
    本篇内容介绍了“SpringBoot怎么集成P6Spy实现SQL日志”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!P6Spy简介P6Spy是...
    99+
    2023-07-04
  • 解析springboot集成AOP实现日志输出的方法
    开发接口系统中主要的一环就是日志输出,如果系统出现问题,日志能帮我们去定位问题,最常见的日志是调用方 所调用的IP 接口地址 对应方法 参数值 以及接口方接收到请求 所返回的参数。如...
    99+
    2024-04-02
  • 【Log日志】springboot项目中集成Log日志详解
    springboot项目中集成Log日志详解 一、Log日志介绍1.Log 日志组件主要作用及用途2.日志的级别Level级别控制 3.日志的输出Import3.1 快速使用3.2 日志文件输出3.3 自定义配置 4. ...
    99+
    2023-08-23
    spring boot java spring Log 日志
  • SpringBoot快速集成Logback日志组件
    目录前言引入:配置:开发:结语前言 在前一节的分享中,慕歌向大家介绍了如何使用spring boot 实现简单的邮寄发送服务,用于验证码服务或者是通知服务。如果大家有兴趣,慕歌还想向...
    99+
    2022-11-13
    SpringBoot集成Logback日志组件 SpringBoot Logback日志
  • SpringBoot集成slf4j日志配置的方法
    目录前言 1、slf4j概述 2、pom.xml的日志依赖 3、application.yml的日志配置 4、logback.xml配置文件定义 5、logback.xml配置文件解...
    99+
    2024-04-02
  • 图文详解SpringBoot中Log日志的集成
    目录一、日志的分类1、名字分类2、日志分类3、日志级别二、logback简介1、 项目中日志分类2、 java项目中使用三、SpringBoot中日志使用 1、将Springboot...
    99+
    2024-04-02
  • Spring boot2.0 实现日志集成的方法(3)
    目录前言具体实现定义日志注解定义日志切面基本使用输出信息总结前言 上一章Spring boot2.0 实现日志集成的方法(2)主要讲解了将日志信息根据类别输出到不...
    99+
    2024-04-02
  • SpringBoot中Log日志集成的示例分析
    这篇文章主要介绍SpringBoot中Log日志集成的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一、日志的分类1、名字分类log4j :log for java (因为for和4读音差不多,所以交log4...
    99+
    2023-06-22
  • Spring boot2.0 实现日志集成的方法(2)
    目录前言:logback.xml配置文件定义引用自定义logback.xml文件附加说明前言: 上一章Spring boot2.0 日志集成方法分享(1)讲解了s...
    99+
    2024-04-02
  • 使用SpringBoot如何实现集成mybatis
    使用SpringBoot如何实现集成mybatis?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。一、使用mybatis-spring-boot-starter添...
    99+
    2023-05-31
    springboot mybatis
  • Springboot如何使用Logback实现日志配置
    这篇文章主要讲解了“Springboot如何使用Logback实现日志配置”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Springboot如何使用Logback实现日志配置”吧!概述默认情...
    99+
    2023-07-04
  • 使用springboot如何实现对mybatis集成
    本篇文章为大家展示了使用springboot如何实现对mybatis集成,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。在pom文件中添加mybatis的依赖: <dependency>...
    99+
    2023-05-31
    springboot mybatis
  • SpringBoot中 log4j日志未生成如何解决
    SpringBoot中 log4j日志未生成如何解决,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。SpringBoot log4j日志没生成从同事那接了一个脚手架,启动后发现日...
    99+
    2023-06-20
  • Django项目中如何集成日志模块?
    Django是一个流行的Python Web框架,用于快速开发Web应用程序。在开发Django应用程序时,日志模块是非常重要的。它可以帮助开发人员在应用程序运行时记录和跟踪事件,从而更好地了解应用程序的行为和性能。 本文将介绍如何在Dja...
    99+
    2023-09-04
    日志 javascript django
  • springboot下mybatis-plus如何打印sql日志和参数到日志文件
    最近在使用springboot过程中用到了mybatis-plus ,springboot版本是2.3.1.RELEASE,mybatis-plus 版本3.2.0。 ...
    99+
    2024-04-02
  • springboot如何整合mybatis将sql打印到日志
    这篇文章主要介绍了springboot如何整合mybatis将sql打印到日志,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。在前台请求数据的时候,sql语句一直都是打印到控制...
    99+
    2023-05-30
    mybatis spring boot
  • SpringBoot3集成SLF4J+logback进行日志记录的实现
    目录1 快速实现2 配置xml2.1 configuration2.2 property和springProperty2.3 root2.4 appender2.4.1 Consol...
    99+
    2024-04-02
  • SpringBoot集成Swagger3的实现
    目录一,什么是swagger?二,SpringBoot 集成swagger3三,swagger3 注解标签使用一,什么是swagger? 1,  Swagger 是一...
    99+
    2024-04-02
  • Python日志文件中如何集成二维码?
    Python是一种广泛使用的编程语言,被许多开发人员用于创建各种类型的应用程序。在开发过程中,日志是一个非常重要的组成部分,它可以帮助开发人员在应用程序中跟踪和记录不同的事件和错误。最近,一些开发人员开始在Python日志文件中集成二维码...
    99+
    2023-07-01
    日志 文件 二维码
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作