这篇文章主要解决以下问题
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