springboot (8) 更换数据源为Druid

本文介绍了如何在Spring Boot项目中替换默认数据源为Druid,详细阐述了配置步骤,包括在pom.xml中添加依赖、数据库访问配置以及连接池参数设置。此外,还讲解了如何通过注解式配置Druid的监控,包括StatViewServlet和WebStatFilter的使用,以实现数据源状态监控和SQL统计。最后提醒在SpringBoot 1.5.4版本中,可能需要创建配置类以使Druid监控生效。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

      Spring Boot默认的数据源是:org.apache.tomcat.jdbc.pool.DataSource,而目前的互联网项目,大多数数据库连接池都使用Druid,它的方便之处在于能够提供强大的监控和扩展功能。目前是JAVA语言中最好的连接池。在本文中将讲述如何配置,如何使用,如何监控

      1.在pom.xml文件中添加依赖

   

<dependency>

            <groupId>com.alibaba</groupId>

            <artifactId>druid</artifactId>

            <version>1.0.18</version>

</dependency>

      2.在application.properties文件中配置数据源信息

    

数据库访问配置

主数据源,默认的

spring.datasource.type=com.alibaba.druid.pool.DruidDataSource

spring.datasource.driver-class-name=com.mysql.jdbc.Driver

spring.datasource.url=jdbc:mysql://localhost:3306/test

spring.datasource.username=root

spring.datasource.password=123456

 

下面为连接池的补充设置,应用到上面所有数据源中

初始化大小,最小,最大

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 FROM DUAL

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

这时候启动应用就可以看到看到打印信息就是使用我们配置的数据源了:

[main] com.alibaba.druid.pool.DruidDataSource   : {dataSource-1} inited

   3.配置监控,本篇介绍使用注解式进行配置

   a、配置servlet

  

 import javax.servlet.annotation.WebInitParam;

import javax.servlet.annotation.WebServlet;

 import com.alibaba.druid.support.http.StatViewServlet;

 /**

 * druid 数据源状态监控.

 @author lsh

*

*/

 @WebServlet(urlPatterns="/druid/*",

           initParams={

                   @WebInitParam(name="allow",value="192.168.1.82,127.0.0.1"),// IP白名单 (没有配置或者为空,则允许所有访问)

                    @WebInitParam(name="deny",value="192.168.1.82"),// IP黑名单 (存在共同时,deny优先于allow)

                    @WebInitParam(name="loginUsername",value="admin"),// 用户名

                    @WebInitParam(name="loginPassword",value="123456"),// 密码

                    @WebInitParam(name="resetEnable",value="false")// 禁用HTML页面上的“Reset All”功能

           }

)

public class DruidStatViewServlet extends StatViewServlet{

    private static final longserialVersionUID = 1L; 

}

   b、配置filter

import javax.servlet.annotation.WebFilter;

import javax.servlet.annotation.WebInitParam;

import com.alibaba.druid.support.http.WebStatFilter;

 

/**

 * druid 过滤器.

 @author lsh

 *

 */

@WebFilter(filterName="druidWebStatFilter",urlPatterns="/*",

    initParams={

             @WebInitParam(name="exclusions",value="*.js,*.gif,*.jpg,*.bmp,*.png,*.css,*.ico,/druid/*")// 忽略资源

     }

)

public class DruidStatFilter extends WebStatFilter{

 }

最后在Application.java类上加上注解:@ServletComponentScan是的spring能够扫描到我们自己编写的servletfilter

注意不要忘记在 SpringBootSampleApplication.java 上添加 @ServletComponentScan 注解,不然就是404了。

然后启动项目后访问 http://127.0.0.1:8080/druid/index.html ,输入用户名密码,即servlet中配置的信息,即可查看数据源及SQL统计等。

注意:如果Druid监控中,监控不到sql,查看application.properties中数据源配置有没有报黄线,本人在测试时发现,在1.5.4版本的springboot中,application.properties中写入Druid配置时,全部报黄线,说明这些配置都没有生效,因此需要写个配置类注入这些配置,这样才能使Druid监控生效。

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.autoconfigure.jdbc.DataSourceProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Primary;
import com.alibaba.druid.pool.DruidDataSource;

/**本版本的springboot只配置application.properties的话,配置不生效
 *<p>Title: DruidDataSourceConfig.java</p>
 *<p>Description: 数据源属性配置</p>
 *@author lsh
 *@version v1.0
 */
@Configuration
@Primary //在同样的DataSource中,首先使用被标注的DataSource
public class DruidDataSourceConfig extends DataSourceProperties{

    private Logger logger = LoggerFactory.getLogger(DruidDataSourceConfig.class);

    @Value("${spring.datasource.url}")  
    private String dbUrl;  

    @Value("${spring.datasource.username}")  
    private String username;  

    @Value("${spring.datasource.password}")  
    private String password;  

    @Value("${spring.datasource.driverClassName}")  
    private String driverClassName;  

    @Value("${spring.datasource.initialSize}")  
    private int initialSize;  

    @Value("${spring.datasource.minIdle}")  
    private int minIdle;  

    @Value("${spring.datasource.maxActive}")  
    private int maxActive;  

    @Value("${spring.datasource.maxWait}")  
    private int maxWait;  

    @Value("${spring.datasource.timeBetweenEvictionRunsMillis}")  
    private int timeBetweenEvictionRunsMillis;  

    @Value("${spring.datasource.minEvictableIdleTimeMillis}")  
    private int minEvictableIdleTimeMillis;  

    @Value("${spring.datasource.validationQuery}")  
    private String validationQuery;  

    @Value("${spring.datasource.testWhileIdle}")  
    private boolean testWhileIdle;  

    @Value("${spring.datasource.testOnBorrow}")  
    private boolean testOnBorrow;  

    @Value("${spring.datasource.testOnReturn}")  
    private boolean testOnReturn;  

    @Value("${spring.datasource.poolPreparedStatements}")  
    private boolean poolPreparedStatements;  

    @Value("${spring.datasource.maxPoolPreparedStatementPerConnectionSize}")  
    private int maxPoolPreparedStatementPerConnectionSize;  

    @Value("${spring.datasource.filters}")  
    private String filters;  

    @Value("{spring.datasource.connectionProperties}")  
    private String connectionProperties;  

    @Bean     //声明其为Bean实例  
    public DataSource dataSource(){  
        DruidDataSource datasource = new DruidDataSource();  

        datasource.setUrl(this.dbUrl);  
        datasource.setUsername(username);  
        datasource.setPassword(password);  
        datasource.setDriverClassName(driverClassName);  

        //configuration  
        datasource.setInitialSize(initialSize);  
        datasource.setMinIdle(minIdle);  
        datasource.setMaxActive(maxActive);  
        datasource.setMaxWait(maxWait);  
        datasource.setTimeBetweenEvictionRunsMillis(timeBetweenEvictionRunsMillis);  
        datasource.setMinEvictableIdleTimeMillis(minEvictableIdleTimeMillis);  
        datasource.setValidationQuery(validationQuery);  
        datasource.setTestWhileIdle(testWhileIdle);  
        datasource.setTestOnBorrow(testOnBorrow);  
        datasource.setTestOnReturn(testOnReturn);  
        datasource.setPoolPreparedStatements(poolPreparedStatements);  
        datasource.setMaxPoolPreparedStatementPerConnectionSize(maxPoolPreparedStatementPerConnectionSize);  
        try {  
            datasource.setFilters(filters);  
        } catch (SQLException e) {  
            logger.error("druid configuration initialization filter", e);  
        }  
        datasource.setConnectionProperties(connectionProperties);  

        return datasource;  
    }
}
### Spring Boot 3 中 Druid 和 HikariCP 冲突解决方案 在 Spring Boot 3 应用程序中,当同时引入 Druid 数据库连接池和 HikariCP 这两个组件时,可能会遇到冲突问题。这是因为两者都试图管理数据库连接池资源,而默认情况下,Spring Boot 使用的是 HikariCP。 #### 配置优先级调整 为了确保应用程序能够正常工作并避免潜在的冲突,可以通过显式指定首选的数据源来解决问题。如果希望使用 Druid 而不是默认的 HikariCP,则应在 `application.properties` 或者 `application.yml` 文件中明确声明这一点: 对于 properties 文件: ```properties spring.datasource.type=com.alibaba.druid.pool.DruidDataSource ``` 对于 yml 文件: ```yaml spring: datasource: type: com.alibaba.druid.pool.DruidDataSource ``` 这会告诉 Spring Boot 不要自动配置 HikariCP 并转而采用 Druid[^2]。 #### 排除默认依赖项 另一种方法是在项目的构建文件 (如 Maven 的 POM.xml) 中排除掉自带的 HikariCP 依赖,从而强制应用只使用 Druid。以下是针对 Maven 构建工具的例子: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-jdbc</artifactId> <exclusions> <exclusion> <groupId>com.zaxxer</groupId> <artifactId>HikariCP</artifactId> </exclusion> </exclusions> </dependency> <!-- 添加 druid --> <dependency> <groupId>com.alibaba</groupId> <artifactId>druid-spring-boot-starter</artifactId> <version>${druid.version}</version> </dependency> ``` 这样做的好处是可以完全移除不需要的类路径上的重复实现,减少内存占用以及可能引发的问题[^1]。 #### 处理特定异常情况 有时即使按照上述方式进行了设置仍然会出现一些特殊类型的错误,比如提到过的 `java.sql.SQLFeatureNotSupportedException` 错误。这类问题是由于某些 JDBC 方法未被支持所引起的。对此建议检查使用的驱动版本是否最新,并确认该驱动确实实现了所需的功能;或者考虑更换其他兼容性更好的JDBC驱动器[^4]。 通过以上措施应该可以有效地解决 Spring Boot 3 环境下 Druid 和 HikariCP 同时存在所带来的大多数常见问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值