SpringBoot整合HikariCP连接池的整合

这篇文章主要解决以下问题

1数据库连接池的整合

2何为连接池?(内存中一块存储“可重用连接对象的空间”)

3为什么使用连接池(提高其性能-反复创建和销毁连接会带来很大的性能损耗)

4为什么说创建连接和销毁连接会有很大性能损耗(底层建立连接使用的是TCP/IP协议,基于此协议创建连接需要三次握手,释放连接需要四次握手)

在C/S架构,提高服务端响应的数据速度降低响应时间影响因素可能有以下几点

1请求数据的传输时间 (数据量,带宽)

2请求数据的处理时间(架构,算法,CPU,磁盘,内存)

3响应数据的传输时间 (数据量,带宽,缓冲)

4响应数据的渲染时间   (html,css,js,images)如果js在head里js文件较大则先执行js再展现数据 如果再body里把数据放在js前面则数据先渲染再执行js

数据库连接池代码设计:

 在系统初始化的时候,在内存中开辟一片空间,将一定数量的数据库连接作为对象存储在对象池里,并对外提供数据库连接的获取和归还方法。用户访问数据库时,并不是建立一个新的连接,而是从数据库连接池中取出一个已有的空闲连接对象;使用完毕归还后的连接也不会马上关闭,而是由数据库连接池统一管理回收,为下一次借用做好准备。如果由于高并发请求导致数据库连接池中的连接被借用完毕,其他线程就会等待,直到有连接被归还。整个过程中,连接并不会关闭,而是源源不断地循环使用,有借有还。数据库连接池还可以通过设置其参数来控制连接池中的初始连接数、连接的上下限数,以及每个连接的最大使用次数、最大空闲时间等,也可以通过其自身的管理机制来监视数据库连接的数量、使用情况等。 私否上看到的很好的总结

 代码设计:

第一步添加依赖

	<dependency>
               <!--当前添加data-jdbc依赖时会自动下载HikariCPy依赖-->
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-data-jdbc</artifactId>
		</dependency>
        <!--连接数据库的驱动-->
		<dependency>
			<groupId>mysql</grou
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值