springboot配置连接rds_第六篇:SpringBoot 2.x添加Druid作为数据库连接池-阿里云开发者社区...

本文介绍了如何在SpringBoot 2.x应用中集成Druid数据库连接池,通过详细配置步骤展示了如何设置Druid的初始化大小、最小、最大连接数以及监控等参数,并提供了通过配置文件和代码方式实现Druid的数据源配置。通过示例展示了访问Druid监控页面以及验证连接池配置成功的方法。
摘要由CSDN通过智能技术生成

整合了一大堆ORM,是时候增加一个连接池了,此处选用了druid作为连接池,druid是alibaba开源平台上的一个数据库连接池实现,对比c3p0,dbcp加入了对数据库的监控,不知道甩出几条街的距离,个人推为数据库连接池的首选(手动摊手)

这里仍然使用jpa+druid

首先先来看看引入的依赖

org.springframework.boot

spring-boot-starter-data-jpa

org.springframework.boot

spring-boot-starter-web

com.alibaba

druid-spring-boot-starter

1.1.10

mysql

mysql-connector-java

runtime

org.springframework.boot

spring-boot-starter-test

test

application.properties

#jdbc配置

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

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

spring.datasource.username=root

spring.datasource.password=root

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

#连接池的设置

#初始化时建立物理连接的个数

spring.datasource.druid.initial-size=5

#最小连接池数量

spring.datasource.druid.min-idle=5

#最大连接池数量 maxIdle已经不再使用

spring.datasource.druid.max-active=20

#获取连接时最大等待时间,单位毫秒

spring.datasource.druid.max-wait=60000

#申请连接的时候检测,如果空闲时间大于timeBetweenEvictionRunsMillis,执行validationQuery检测连接是否有效。

spring.datasource.druid.test-while-idle=true

#既作为检测的间隔时间又作为testWhileIdel执行的依据

spring.datasource.druid.time-between-eviction-runs-millis=60000

#销毁线程时检测当前连接的最后活动时间和当前时间差大于该值时,关闭当前连接

spring.datasource.druid.min-evictable-idle-time-millis=30000

#用来检测连接是否有效的sql 必须是一个查询语句

#mysql中为 select 'x'

#oracle中为 select 1 from dual

spring.datasource.druid.validation-query=select 'x'

#申请连接时会执行validationQuery检测连接是否有效,开启会降低性能,默认为true

spring.datasource.druid.test-on-borrow=false

#归还连接时会执行validationQuery检测连接是否有效,开启会降低性能,默认为true

spring.datasource.druid.test-on-return=false

#当数据库抛出不可恢复的异常时,抛弃该连接

spring.datasource.druid.exception-sorter=true

#是否缓存preparedStatement,mysql5.5+建议开启

#spring.datasource.druid.pool-prepared-statements=true

#当值大于0时poolPreparedStatements会自动修改为true

spring.datasource.druid.max-pool-prepared-statement-per-connection-size=20

#配置扩展插件

spring.datasource.druid.filters=stat,wall

#通过connectProperties属性来打开mergeSql功能;慢SQL记录

spring.datasource.druid.connection-properties=druid.stat.mergeSql=true;druid.stat.slowSqlMillis=500

#合并多个DruidDataSource的监控数据

spring.datasource.druid.use-global-data-source-stat=true

#设置访问druid监控页的账号和密码,默认没有

#spring.datasource.druid.stat-view-servlet.login-username=admin

#spring.datasource.druid.stat-view-servlet.login-password=admin

#jpa设置

spring.jpa.database=mysql

spring.jpa.show-sql=true

spring.jpa.hibernate.ddl-auto=update

关于jpa的搭建的话,建议查看这个SpringBoot整合JPA

如果是按照我这种方式的话,那么现在就已经整合完毕了

接来下访问一下druid的监控页druid

image.png

再看看连接池的配置成功没有

image.png

以及sql的监控

image.png

还记得上面说的druid的两种配置方式吗,上一种的话,只需要我们写好配置文件就OK了,而下一种就麻烦一点,我在这里还是把代码贴上

package com.priv.gabriel;

import com.alibaba.druid.pool.DruidDataSource;

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

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

import org.springframework.boot.context.properties.ConfigurationProperties;

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 javax.sql.DataSource;

/**

* Created with Intellij IDEA.

*

* @Author: Gabriel

* @Date: 2018-10-10

* @Desciption:

*/

@Configuration

public class DruidConfig {

@Bean

@ConfigurationProperties(prefix = "spring.datasource")

public DataSource druid(){

return new DruidDataSource();

}

@Bean

public ServletRegistrationBean druidServlet(){

ServletRegistrationBean bean = new ServletRegistrationBean(new StatViewServlet(),"/druid/*");

bean.addInitParameter("allow","127.0.0.1");

bean.addInitParameter("resetEnable","false");

bean.addInitParameter("loginUsername","admin");

bean.addInitParameter("loginPassword","admin");

return bean;

}

@Bean

public FilterRegistrationBean statFilter(){

FilterRegistrationBean bean = new FilterRegistrationBean(new WebStatFilter());

bean.addUrlPatterns("/*");

bean.addInitParameter("exclusions","*.js,*.gif,/druid/*");

return bean;

}

}

这种方式需要我们手动的写上一个servlet以及filter,注意:这里必须要手动的注入一个DruidDataSource而且指定去读取文件,不然它是不会初始化数据源的 [这么个问题搞了半个多小时]

好了,现在druid的已经整合完毕啦。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值