mysql spring 连接池_SpringBoot--连接池(HikariCP)

SpringBoot整合连接池

1.1 概述

在实际开发的过程中,应用程序与数据库交互,"获得连接"和"释放资源"是非常消耗系统资源的两个过程,为了解决此类性能问题,通常情况下我们采用连接池技术来重用连接Connection对象;

Java为数据库连接池提供了公共的接口:javax.sql.DataSource;都需要将自己的数据库实现这个接口.然后我们的应用程序中耦合于这个接口,便可以切换不同的连接池,常见的连接池有DBCP,C3P0,DRUID,HikariCP等!!!

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

da37ae26b94ed68119fc04a37bed40b6.png

在上图中.用户会通过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

590142f11609b1a10b0bf75a58dbf1e7.png

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

39a48794f47d42efe536dc13cfd889d5.png

第二步:配置连接池

打开applecation.properties配置文件,添加以下内容:

spring.datasource.url=jdbc:mysql:///dbgoods?serverTimezone=GMT%2B8&characterEncoding=utf8

spring.datasource.username=root

spring.datasource.password=root`

第三步:单元测试

8ec77f7ecba002a24cd695738ef6ccd2.png

第四步:原理分析

8ec77f7ecba002a24cd695738ef6ccd2.png

在上图中,演示了我们在测试类DataSourceTests中基于DataSource获取连接的一个基本过程. 可以再Driver接口实现中的connet方法添加断点,然后进行断点测试

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值