Spring Boot 使用Druid详解

发布时间 - 2026-01-11 01:11:31    点击率:

Druid是Java语言中最好的数据库连接池,并且能够提供强大的监控和扩展功能,下面来说明如何在 SpringBoot 中配置使用Druid。
步骤:

1. 在pom.xml中加载依赖

2. 在application.properties中加入数据源配置

3. 编写DruidConfiguration,通过@Bean注解的方式注入druid servlet和filter,以便提供监控页面访问

4. 浏览器访问

一、在pom.xml中加入依赖

<dependency> 
      <groupId>com.alibaba</groupId> 
      <artifactId>druid</artifactId> 
      <version>1.0.18</version> 
  </dependency> 

二、在application.properties中加入数据源配置

################## server ################################ 
server.port=8080 
 
################## datasource ################################ 
spring.datasource.url = jdbc:mysql://localhost:3306/spring 
spring.datasource.username = root 
spring.datasource.password = 123456 
spring.datasource.driverClassName = com.mysql.jdbc.Driver 
 
#使用Druid数据源 
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource 
# 下面为连接池的补充设置,应用到上面所有数据源中 
 
# 初始化大小,最小,最大 
spring.datasource.initialSize=5 
spring.datasource.minIdle=5 
spring.datasource.maxActive=20 
 
# 配置获取连接等待超时的时间 
spring.datasource.maxWait=60000 
 
# 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 
spring.datasource.timeBetweenEvictionRunsMillis=60000 
 
# 配置一个连接在池中最小生存的时间,单位是毫秒 
spring.datasource.minEvictableIdleTimeMillis=300000 
spring.datasource.validationQuery=SELECT 1 FROMDUAL 
spring.datasource.testWhileIdle=true 
spring.datasource.testOnBorrow=false 
spring.datasource.testOnReturn=false 
 
# 打开PSCache,并且指定每个连接上PSCache的大小 
spring.datasource.poolPreparedStatements=true 
spring.datasource.maxPoolPreparedStatementPerConnectionSize=20 
 
# 配置监控统计拦截的filters,去掉后监控界面sql无法统计,'wall'用于防火墙 
spring.datasource.filters=stat,wall,log4j 
 
# 通过connectProperties属性来打开mergeSql功能;慢SQL记录 
spring.datasource.connectionProperties=druid.stat.mergeSql=true;druid.stat.slowSqlMillis=5000 
 
# 合并多个DruidDataSource的监控数据 
#spring.datasource.useGlobalDataSourceStat=true 
 
 
################ Java Persistence Api ########################### 
# Specify the DBMS 
spring.jpa.database = MYSQL 
# Show or not log for each sql query 
spring.jpa.show-sql = true 
# Hibernate ddl auto (create, create-drop, update) 
spring.jpa.hibernate.ddl-auto = update 
#[org.hibernate.cfg.ImprovedNamingStrategy #org.hibernate.cfg.DefaultNamingStrategy] 
spring.jpa.hibernate.naming-strategy = org.hibernate.cfg.ImprovedNamingStrategy 
# stripped before adding them to the entity manager) 
spring.jpa.properties.hibernate.dialect= org.hibernate.dialect.MySQL5Dialect 
 
#暂时不用redis,所以none,spring.session.store-type=reids 
spring.session.store-type=none 

以上是我项目中的配置信息,大家只要关注datasource部分即可。

三、编写DruidConfiguration配置类,通过@Bean注解的方式注入druid servlet和filter,以便提供监控页面访问

package com.example.config; 
 
import java.sql.SQLException; 
 
import javax.sql.DataSource; 
 
import org.slf4j.Logger; 
import org.slf4j.LoggerFactory; 
import org.springframework.beans.factory.annotation.Value; 
import org.springframework.boot.web.servlet.FilterRegistrationBean; 
import org.springframework.boot.web.servlet.ServletRegistrationBean; 
import org.springframework.context.annotation.Bean; 
import org.springframework.context.annotation.Configuration; 
 
import com.alibaba.druid.pool.DruidDataSource; 
import com.alibaba.druid.support.http.StatViewServlet; 
import com.alibaba.druid.support.http.WebStatFilter; 
 
/** 
 * 配置druid数据源 
 * 
 */ 
@Configuration 
public class DruidConfiguration { 
   
  private Logger logger = LoggerFactory.getLogger(DruidConfiguration.class); 
 
  @Bean 
  public ServletRegistrationBean druidStatViewServlet() { 
    ServletRegistrationBean registrationBean = new ServletRegistrationBean(new StatViewServlet(), "/druid/*"); 
    registrationBean.addInitParameter("allow", "127.0.0.1"); 
    registrationBean.addInitParameter("deny", "192.168.31.234"); 
    registrationBean.addInitParameter("loginUsername", "admin"); 
    registrationBean.addInitParameter("loginPassword", "123456"); 
    registrationBean.addInitParameter("resetEnable", "false"); 
 
    return registrationBean; 
  } 
 
  @Bean 
  public FilterRegistrationBean druidWebStatViewFilter() { 
    FilterRegistrationBean registrationBean = new FilterRegistrationBean(new WebStatFilter()); 
    registrationBean.addInitParameter("urlPatterns", "/*"); 
    registrationBean.addInitParameter("exclusions", "*.js,*.gif,*.jpg,*.bmp,*.png,*.css,*.ico,/druid/*"); 
 
    return registrationBean; 
 
  } 
 
  @Bean 
  public DataSource druidDataSource(@Value("${spring.datasource.url}") String url, 
      @Value("${spring.datasource.driverClassName}") String driver, 
      @Value("${spring.datasource.username}") String userName, 
      @Value("${spring.datasource.password}") String password, 
      @Value("${spring.datasource.maxActive}") int maxActive, 
      @Value("${spring.datasource.filters}") String filters, 
      @Value("${spring.datasource.initialSize}") 
      int initialSize, 
      @Value("${spring.datasource.minIdle}") 
      int minIdle, 
      @Value("${spring.datasource.maxWait}") 
      int maxWait, 
      @Value("${spring.datasource.timeBetweenEvictionRunsMillis}") 
      int timeBetweenEvictionRunsMillis, 
      @Value("${spring.datasource.minEvictableIdleTimeMillis}") 
      int minEvictableIdleTimeMillis, 
      @Value("${spring.datasource.validationQuery}") 
      String validationQuery, 
      @Value("${spring.datasource.testWhileIdle}") 
      boolean testWhileIdle, 
      @Value("${spring.datasource.testOnBorrow}") 
      boolean testOnBorrow, 
      @Value("${spring.datasource.testOnReturn}") 
      boolean testOnReturn, 
      @Value("${spring.datasource.poolPreparedStatements}") 
      boolean poolPreparedStatements, 
      @Value("${spring.datasource.maxPoolPreparedStatementPerConnectionSize}") 
      int maxPoolPreparedStatementPerConnectionSize, 
      @Value("${spring.datasource.connectionProperties}") 
      String connectionProperties, 
      @Value("${spring.datasource.useGlobalDataSourceStat}") 
      boolean useGlobalDataSourceStat 
 
  ) { 
    DruidDataSource dataSource = new DruidDataSource(); 
    /*数据源主要配置*/ 
    dataSource.setUrl(url); 
    dataSource.setDriverClassName(driver); 
    dataSource.setUsername(userName); 
    dataSource.setPassword(password); 
     
    /*数据源补充配置*/ 
    dataSource.setMaxActive(maxActive); 
    dataSource.setInitialSize(initialSize); 
    dataSource.setMinIdle(minIdle); 
    dataSource.setMaxWait(maxWait); 
    dataSource.setTimeBetweenEvictionRunsMillis(timeBetweenEvictionRunsMillis); 
    dataSource.setMinEvictableIdleTimeMillis(minEvictableIdleTimeMillis); 
    dataSource.setValidationQuery(validationQuery); 
    dataSource.setTestOnBorrow(testOnBorrow); 
    dataSource.setTestOnReturn(testOnReturn); 
    dataSource.setTestWhileIdle(testWhileIdle); 
    dataSource.setPoolPreparedStatements(poolPreparedStatements); 
    dataSource.setMaxPoolPreparedStatementPerConnectionSize(maxPoolPreparedStatementPerConnectionSize); 
    dataSource.setConnectionProperties(connectionProperties); 
    dataSource.setUseGlobalDataSourceStat(useGlobalDataSourceStat); 
     
    try { 
      dataSource.setFilters(filters); 
      logger.info("Druid数据源初始化设置成功......"); 
    } catch (SQLException e) { 
      e.printStackTrace(); 
      logger.info("Druid数据源filters设置失败......"); 
    } 
    return dataSource; 
 
  } 
} 

四、浏览器访问

在浏览器中输入http://localhost:8080/druid/index.html,首次访问需要使用账号和密码登录


在数据源一栏中,所有加"*"标识的都不能为空,,尤其是filter类名,否则会看不到SQL监控数据。

五、查看SQL监控

执行删除某条记录后,查看SQL监控

到这里,我们就把druid配置成功了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# Spring  # Boot  # 使用Druid  # springboot  # druid配置  # 通过springboot+mybatis+druid配置动态数据源  # springboot 动态数据源的实现方法(Mybatis+Druid)  # Spring Boot使用Druid连接池的示例代码  # Spring Boot+Mybatis+Druid+PageHelper实现多数据源并分页的方法  # SpringBoot使用Druid数据源的配置方法  # SpringBoot开发案例之配置Druid数据库连接池的示例  # 详解Spring Boot下Druid连接池的使用配置分析  # Spring Boot 整合 Druid过程解析  # 连接池  # 都不  # 最好的  # 尤其是  # 首次  # 多个  # 就把  # 能为  # 则会  # 大家多多  # 栏中  # 池中  # 器中  # 加载  # 多久  # 如何在  # true  # testOnBorrow  # DruidDataSource  # FROMDUAL 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 夸克浏览器网页跳转延迟怎么办 夸克浏览器跳转优化  网站建设要注意的标准 促进网站用户好感度!  家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?  Laravel如何为API编写文档_Laravel API文档生成与维护方法  5种Android数据存储方式汇总  Laravel Debugbar怎么安装_Laravel调试工具栏配置指南  极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?  Laravel PHP版本要求一览_Laravel各版本环境要求对照  Laravel如何实现API版本控制_Laravel版本化API设计方案  JavaScript中的标签模板是什么_它如何扩展字符串功能  CSS3怎么给轮播图加过渡动画_transition加transform实现【技巧】  JS碰撞运动实现方法详解  什么是JavaScript解构赋值_解构赋值有哪些实用技巧  Laravel 419 page expired怎么解决_Laravel CSRF令牌过期处理  合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?  微信推文制作网站有哪些,怎么做微信推文,急?  如何在 Go 中优雅地映射具有动态字段的 JSON 对象到结构体  UC浏览器如何设置启动页 UC浏览器启动页设置方法  PHP 实现电台节目表的智能时间匹配与今日/明日轮播逻辑  猎豹浏览器开发者工具怎么打开 猎豹浏览器F12调试工具使用【前端必备】  Linux虚拟化技术教程_KVMQEMU虚拟机安装与调优  如何挑选优质建站一级代理提升网站排名?  Linux系统命令中tree命令详解  ChatGPT怎么生成Excel公式_ChatGPT公式生成方法【指南】  如何快速完成中国万网建站详细流程?  Laravel如何升级到最新的版本_Laravel版本升级流程与兼容性处理  Python文件异常处理策略_健壮性说明【指导】  齐河建站公司:营销型网站建设与SEO优化双核驱动策略  nginx修改上传文件大小限制的方法  网页设计与网站制作内容,怎样注册网站?  如何在HTML表单中获取用户输入并结合JavaScript动态控制复利计算循环  如何在万网利用已有域名快速建站?  想要更高端的建设网站,这些原则一定要坚持!  Win11摄像头无法使用怎么办_Win11相机隐私权限开启教程【详解】  如何快速重置建站主机并恢复默认配置?  零服务器AI建站解决方案:快速部署与云端平台低成本实践  Laravel怎么使用Session存储数据_Laravel会话管理与自定义驱动配置【详解】  Python进程池调度策略_任务分发说明【指导】  Laravel用户认证怎么做_Laravel Breeze脚手架快速实现登录注册功能  如何制作一个表白网站视频,关于勇敢表白的小标题?  详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)  Laravel如何实现密码重置功能_Laravel密码找回与重置流程  胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?  BootStrap整体框架之基础布局组件  在Oracle关闭情况下如何修改spfile的参数  Laravel怎么自定义错误页面_Laravel修改404和500页面模板  利用 Google AI 进行 YouTube 视频 SEO 描述优化  香港服务器租用费用高吗?如何避免常见误区?  如何登录建站主机?访问步骤全解析  Laravel如何使用集合(Collections)进行数据处理_Laravel Collection常用方法与技巧