从零开始SpringBoot2.x【五】使用连接池(Druid)创建Datasource

为什么需要数据库连接池?

1. 资源重用
2. 更快的系统响应速度
3. 新的资源分配手段
4. 统一的连接管理,避免数据库连接泄漏

为什么是Druid?

 Druid是由阿里巴巴数据库事业部出品的开源项目。它除了是一个高性能数据库连接池之外,更是一个自带监控的数据库连接池。其实在Springboot的默认连接池是HikariCP,虽然HikariCP已经很优秀,但是对于国内用户来说,可能对于Druid更为熟悉。所以,对于如何在Spring Boot中使用Druid是后端开发人员必须要掌握的基本技能。

Druid官方文档:https://github.com/alibaba/druid/wiki/%E5%B8%B8%E8%A7%81%E9%97%AE%E9%A2%98

spring-boot-druid:https://github.com/alibaba/druid/tree/master/druid-spring-boot-starter

那么我们先就开始快速体验一下Druid吧。

1、引入相关的依赖,直接引入druid官方提供的Spring Boot Starter封装,我们修改pom.xml


    com.alibaba
    druid-spring-boot-starter
    1.1.21

 

2、在application.properties配置数据源,所有的druid的配置都是以spring.datasource.druid开头

spring.datasource.druid.url=jdbc:mysql://localhost:3306/test
spring.datasource.druid.username=root
spring.datasource.druid.password=123456
#driverClassName可以不配置,druid会自动根据url协议来识别需要的驱动
spring.datasource.druid.driver-class-name=com.mysql.cj.jdbc.Driver

3、完整的spring.datasource.druid的配置,要用好一个数据源,还需要调整相关的数据源配置

#配置这个属性的意义在于,如果存在多个数据源,监控的时候可以通过名字来区分开来。如果没有配置,将会生成一个名字,格式是:”DataSource-“ + System.identityHashCode(this)
spring.datasource.druid.name=masterDatasource
#初始化时建立物理连接的个数。初始化发生在显示调用init方法,或者第一次getConnection时
spring.datasource.druid.initialSize=10
#最大连接池数量
spring.datasource.druid.maxActive=20
#获取连接时最大等待时间,单位毫秒。配置了maxWait之后,缺省启用公平锁,并发效率会有所下降,如果需要可以通过配置useUnfairLock属性为true使用非公平锁。
spring.datasource.druid.maxWait=60000
#最小连接池数量
spring.datasource.druid.minIdle=1
#有两个含义: 
   1) Destroy线程会检测连接的间隔时间,如果连接空闲时间大于等于minEvictableIdleTimeMillis则关闭物理连接。
   2) testWhileIdle的判断依据,详细看testWhileIdle属性的说明
spring.datasource.druid.timeBetweenEvictionRunsMillis=60000
#连接保持空闲而不被驱逐的最小时间
spring.datasource.druid.minEvictableIdleTimeMillis=300000
# 空闲时间开启查询,建议配置为true,不影响性能,并且保证安全性。申请连接的时候检测,如果空闲时间大于timeBetweenEvictionRunsMillis,执行validationQuery检测连接是否有效
spring.datasource.druid.testWhileIdle=true
#连接池中的minIdle数量以内的连接,空闲时间超过minEvictableIdleTimeMillis,则会执行keepAlive操作。
spring.datasource.druid.keepAlive=true
spring.datasource.druid.testOnBorrow=true
spring.datasource.druid.testOnReturn=false
spring.datasource.druid.poolPreparedStatements=true
spring.datasource.druid.maxOpenPreparedStatements=20
spring.datasource.druid.validationQuery=SELECT 1
spring.datasource.druid.validation-query-timeout=500
#属性类型是字符串,通过别名的方式配置扩展插件,
常用的插件有: 
      1、监控统计用的filter:stat 
      2、日志用的filter:log4j 
      3、防御sql注入的filter:wall
spring.datasource.druid.filters=stat

 到此我们已经完成了Durid的切换了,其他的业务逻辑代码我们基本不需要用。

下一节我们补充关于Druid监控的配置!

 

你可能感兴趣的:(JAVA,基础,Spring,JPA,mysql,java,spring)