Druid 内置Filter配置

Druid Spring Boot Starter 对以下 Druid 内置 Filter,都提供了默认配置:

  • StatFilter 通过它可以开启 Druid 的 SQL 监控功能,对 SQL 进行监控。
  • WallFilter 使用它可以开启防火墙功能,防御 SQL 注入攻击。
  • ConfigFilter
  • EncodingConvertFilter
  • Slf4jLogFilter
  • Log4jFilter
  • CommonsLogFilter我们可以通过spring.datasource.druid.filters=stat,wall … 的方式来启用相应的内置 Filter,不过这些 Filter 使用的都是默认配置。如果默认配置不能满足我们的需求,我们还可以在配置文件使用 spring.datasource.druid.filter.* 对这些 Filter 进行配置,示例代码如下:
#Druid 内置Filter配置
spring:
    datasource:
      druid:
        #对配置已开启的 filters 即 stat(sql 监控)wall(防火墙)
        filter:
          #配置StatFilter (SQL监控配置)
          stat:
            enabled: true #开启 SQL 监控
            slow-sql-millis: 1000 #慢查询
            log-slow-sql: true #记录慢查询 SQL
          #配置WallFilter (防火墙配置)
          wall:
            enabled: true #开启防火墙
            config:
              update-allow: true #允许更新操作
              drop-table-allow: false #禁止删表操作
              insert-allow: true #允许插入操作
              delete-allow: true #删除数据操作

在配置 Druid 内置 Filter 时,需要先将对应 Filter 的enabled 设置为 true,否则内置 Filter 的配置不会生效。
启动应用程序(http://localhost:8080/druid)后,通过web访问数据库,再通过内置监控页面可以查看相关监控信息

  • 6
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Spring Boot中使用Druid连接池进行MySQL的线程池配置,你可以按照以下步骤进行操作: 1. 首先,在你的Spring Boot项目的pom.xml文件中添加Druid和MySQL的依赖: ```xml <dependency> <groupId>com.alibaba</groupId> <artifactId>druid-spring-boot-starter</artifactId> <version>1.2.6</version> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> </dependency> ``` 2. 在application.properties(或application.yml)文件中配置Druid连接池的参数: ```properties # 数据源配置 spring.datasource.url=jdbc:mysql://localhost:3306/db_name spring.datasource.username=username spring.datasource.password=password spring.datasource.driver-class-name=com.mysql.jdbc.Driver # Druid相关配置 spring.datasource.druid.initial-size=5 spring.datasource.druid.min-idle=5 spring.datasource.druid.max-active=20 spring.datasource.druid.max-wait=60000 spring.datasource.druid.time-between-eviction-runs-millis=60000 spring.datasource.druid.min-evictable-idle-time-millis=300000 spring.datasource.druid.test-while-idle=true spring.datasource.druid.test-on-borrow=false spring.datasource.druid.test-on-return=false spring.datasource.druid.pool-prepared-statements=true spring.datasource.druid.max-pool-prepared-statement-per-connection-size=20 spring.datasource.druid.filters=stat,wall,log4j ``` 3. 创建一个配置类,用于配置Druid数据源: ```java import com.alibaba.druid.pool.DruidDataSource; import org.springframework.boot.context.properties.ConfigurationProperties; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import javax.sql.DataSource; @Configuration public class DruidConfig { @Bean @ConfigurationProperties(prefix = "spring.datasource") public DataSource druidDataSource() { return new DruidDataSource(); } } ``` 4. 在主启动类上加上`@EnableConfigurationProperties(DruidConfig.class)`注解,以启用Druid配置。 现在,你的Spring Boot项目已经配置好了使用Druid连接池进行MySQL的线程池配置。你可以根据实际需求调整Druid的参数,比如连接池的大小、最大等待时间等。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

roydon_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值