SpringBoot整合连接池

1.1 概述

在理论开发的过程中,应用程序与数据库交互,"取得连贯"和"开释资源"是十分耗费系统资源的两个过程,为了解决此类性能问题,通常状况下咱们采纳连接池技术来重用连贯Connection对象;

Java为数据库连接池提供了公共的接口:javax.sql.DataSource;都须要将本人的数据库实现这个接口.而后咱们的应用程序中耦合于这个接口,便能够切换不同的连接池,常见的连接池有DBCP,C3P0,DRUID,HikariCP等!!!


通过连接池获取连贯的一个根本过程如下图:

在上图中.用户会通过DataSource(数据源)对象的getConnection()办法,获取一个连贯.如果池中有连贯,则间接将连贯返回给用户.如果池中没有连贯.则会调用Dirver(驱动,由数据库厂商进行实现)对象的connet办法从数据库获取.拿到连贯后,能够将连贯在池中放一份,而后将连贯返回给调用方;

1.2数据初始化

第一步:登录mysql
第二步:设置客户端控制台的编码(utf8)
第三步:执行.sql文件
备注:当mysql连贯数据库失败时,检测服务是否启动,可尝试先启动服务(windows中须要以管理员关上控制台,而后在控制台执行net start mysql启动服务即可)

1.3整合HikariCP连接池

HakariCP号称是目前世界上最快的连接池,有江湖一哥的名称.目前在SpringBoot工程默认应用HakariCP连接池;在SpringBoot工程中整合HakariCP,步骤如下:
第一步:增加依赖
1.在pom.xml中,右键Spring--->Edit Starters

2.查找Mysql驱动依赖,JDBC API

第二步:配置连接池
关上applecation.properties配置文件,增加以下内容:
spring.datasource.url=jdbc:mysql:///dbgoods?serverTimezone=GMT%2B8&characterEncoding=utf8
spring.datasource.username=root
spring.datasource.password=root`

第三步:单元测试

第四步:原理剖析

在上图中,演示了咱们在测试类DataSourceTests中基于DataSource获取连贯的一个根本过程. 能够再Driver接口实现中的connet办法增加断点,而后进行断点测试