SpringBoot -集成Druid

Druid

概述

官网: https://github.com/alibaba/druid

文档: https://github.com/alibaba/druid/wiki

基础配置列表: https://github.com/alibaba/druid/wiki/DruidDataSource配置属性列表

参考配置: https://github.com/alibaba/druid/wiki/DruidDataSource配置

依赖: https://mvnrepository.com/artifact/com.alibaba/druid-spring-boot-starter

内置过滤器的名字参考: com\alibaba\druid\1.2.15\druid-1.2.15.jar!\META-INF\druid-filter.properties


内置过滤器的名字参考:com\alibaba\druid\1.2.15\druid-1.2.15.jar!\META-INF\druid-filter.properties
在这里插入图片描述


配置读取类:com.alibaba.druid.spring.boot.autoconfigure.DruidDataSourceAutoConfigure
在这里插入图片描述


Druid支持的数据类型:com.alibaba.druid.DbType
在这里插入图片描述

使用

Druid管理访问: http://127.0.0.1:9999/druid/

在这里插入图片描述


pom.yml

<!-- https://mvnrepository.com/artifact/com.alibaba/druid-spring-boot-starter -->
<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>druid-spring-boot-starter</artifactId>
    <version>1.2.15</version>
</dependency>


application.yml

spring:
  datasource:
    driver-class-name: com.p6spy.engine.spy.P6SpyDriver
    druid:
      web-stat-filter:
        enabled: true
        exclusions: '*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*'
        session-stat-enable: true
        profile-enable: true
        url-pattern: /*
      # web页面开启
      stat-view-servlet:
        enabled: true
        login-username: root
        login-password: root
        url-pattern: /druid/*
        
      
      filters: stat,wall,mergeStat
      # 配置初始化大小、最小、最大
      min-idle: 10
      initial-size: 5
      max-active: 20
      # 配置获取连接等待超时的时间
      max-wait: 6000
      
      #  配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒
      time-between-eviction-runs-millis: 10000
      
      #  配置一个连接在池中最小生存的时间,单位是毫秒
      min-evictable-idle-time-millis: 600000
      max-evictable-idle-time-millis: 1000000
      
      validation-query: SELECT 1 FROM DUAL
      test-while-idle: true
      test-on-borrow: false
      test-on-return: false
      keep-alive: true
      phy-max-use-count: 100
      db-type: mysql
      
      # 坑,无排除选项,且值必须是逗号分割的字符串数组,建议参考com.alibaba.druid.spring.boot.autoconfigure.stat.DruidSpringAopConfiguration自行配置注入相关Bean
      #aop-patterns: "work.linruchang.*,work.linruchang.config.*,"
  


SpringConfig.java - 配置Druid的Spring监控

@Configuration
public class SpringConfig  implements WebMvcConfigurer {
    @Bean
    public DruidStatInterceptor druidStatInterceptor() {
        DruidStatInterceptor dsInterceptor = new DruidStatInterceptor();
        return dsInterceptor;
    }

    @Bean
    public JdkRegexpMethodPointcut druidStatPointcut() {
        JdkRegexpMethodPointcut pointcut = new JdkRegexpMethodPointcut();
        pointcut.setPattern("work.linruchang.*");//根据实际包名
        pointcut.setExcludedPatterns("work.linruchang.kafkaUiLite.conf.*", ".*config.*");
        return pointcut;
    }

    @Bean
    public DefaultPointcutAdvisor druidStatAdvisor(DruidStatInterceptor druidStatInterceptor, JdkRegexpMethodPointcut druidStatPointcut) {
        DefaultPointcutAdvisor defaultPointAdvisor = new DefaultPointcutAdvisor();
        defaultPointAdvisor.setPointcut(druidStatPointcut);
        defaultPointAdvisor.setAdvice(druidStatInterceptor);
        return defaultPointAdvisor;
    }
}

问题解决

Spring监控不生效
方式1:修改yml的配置写法

参考类: com.alibaba.druid.spring.boot.autoconfigure.stat.DruidSpringAopConfiguration

个人怀疑:@ConditionalOnProperty仅能识别到字符串,不能识别yml形式的数组语法

在这里插入图片描述


applicaiton.yml == 正确写法

spring:
  datasource:
    druid:
      # 坑,缺少排除选项,且值必须是逗号分割的字符串数组才行,个人建议还是使用自行设置JdkRegexpMethodPointcut拦截切面
      aop-patterns: "work.linruchang.*,work.linruchang.config.*"


applicaiton.yml == 错误写法

spring:
  datasource:
    druid:
      # 坑,无排除选项,且值必须是逗号分割的字符串数组,虽然通过@Value能获取到数组,但是不能被@ConditionalOnProperty注解识别到
      aop-patterns: 
        - "work.linruchang.*"
        - "work.linruchang.config.*"
方式2:参考DruidSpringAopConfiguration自行注入@Bean,灵活(更建议)
@Configuration
public class SpringConfig  implements WebMvcConfigurer {
    @Bean
    public DruidStatInterceptor druidStatInterceptor() {
        DruidStatInterceptor dsInterceptor = new DruidStatInterceptor();
        return dsInterceptor;
    }

    @Bean
    public JdkRegexpMethodPointcut druidStatPointcut() {
        JdkRegexpMethodPointcut pointcut = new JdkRegexpMethodPointcut();
        pointcut.setPattern("work.linruchang.*");//根据实际包名
        pointcut.setExcludedPatterns("work.linruchang.kafkaUiLite.conf.*", ".*config.*");
        return pointcut;
    }

    @Bean
    public DefaultPointcutAdvisor druidStatAdvisor(DruidStatInterceptor druidStatInterceptor, JdkRegexpMethodPointcut druidStatPointcut) {
        DefaultPointcutAdvisor defaultPointAdvisor = new DefaultPointcutAdvisor();
        defaultPointAdvisor.setPointcut(druidStatPointcut);
        defaultPointAdvisor.setAdvice(druidStatInterceptor);
        return defaultPointAdvisor;
    }
}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
抱歉,SpringBoot 3.0 目前还没有正式发布。但是,我可以给你提供 SpringBoot 2.x 版本集成 Druid 数据库连接池的代码示例。 首先,在 pom.xml 文件中添加以下依赖: ```xml <!-- Druid 数据库连接池 --> <dependency> <groupId>com.alibaba</groupId> <artifactId>druid-spring-boot-starter</artifactId> <version>1.2.5</version> </dependency> ``` 然后,在 application.properties 文件中添加以下配置: ```properties # 数据库连接配置 spring.datasource.url=jdbc:mysql://localhost:3306/dbname?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=UTC spring.datasource.username=root spring.datasource.password=root spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver # Druid 连接池配置 spring.datasource.druid.initial-size=5 spring.datasource.druid.min-idle=5 spring.datasource.druid.max-active=20 spring.datasource.druid.test-on-borrow=true spring.datasource.druid.test-on-return=false spring.datasource.druid.test-while-idle=true spring.datasource.druid.validation-query=SELECT 1 spring.datasource.druid.filters=stat,wall,log4j spring.datasource.druid.connection-properties=druid.stat.mergeSql=true;druid.stat.slowSqlMillis=5000 ``` 最后,在启动类中加上 `@EnableTransactionManagement` 注解来开启事务支持,并将数据源设置为 Druid 数据源: ```java @SpringBootApplication @EnableTransactionManagement public class YourApplication { @Bean @ConfigurationProperties(prefix = "spring.datasource.druid") public DataSource dataSource() { return DruidDataSourceBuilder.create().build(); } public static void main(String[] args) { SpringApplication.run(YourApplication.class, args); } } ``` 以上就是 SpringBoot 集成 Druid 的基本配置。你可以根据自己的实际情况进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值