springboot hikari连接不释放_Spring Boot 如何整合连接池_java

Spring Boot 整合连接池

在实际开发中应用程序与数据库交互时,“获得连接”或在“释放资源”是非常消耗资源的两个过程,为了解决如此类性能问题,通常这种情况我们采用连接池技术重用连接Connection对象,如图1所示。

springboot hikari连接不释放_Spring Boot 如何整合连接池_java
图-2

在图-2中,用户先通过DataSource对象的getConnection()方法,获取一个连接,如果池中有连接,则直接将连接返回给用户。如果池中没有连接,则会调用Dirver(驱动)对象的connect方法从数据库获取,拿到连接后,可以将连接在连接池中也放一份,然后再将连接返回给调用用户。

一、整合HikariCP连接池

HikariCP号称是目前世界上最快的连接池,有江湖一哥的称号,目前在SpringBoot工程默认推荐使用HikariCP连接池。我们在创建一个新项目时步骤如下:

第一步:添加依赖。

编辑项目中的,查找MySQL Driver、JDBC API 依赖,依赖添加后,会在文件中自动添加如下两个依赖配置:

数据库驱动依赖。

对象jdbc支持(此时会默认帮我们下载HiKariCP连接池)

第二步:配置连接池。

打开配置文件,添加如下内容。

第三步:进行单元测试。

第四步:原理分析,如图-3所示。

springboot hikari连接不释放_Spring Boot 如何整合连接池_java

图-4

在当前互联网应用项目中,MyBatis框架通常会由spring框架进行资源整合,作为技术层实现数据交互操作。

1、初始配置

添加mybatis启动依赖
参考mybatis官网,找到springboot菜单选项。基于菜单项找到MyBatis启动依赖。

注意: 在添加此依赖时,一定指定其版本(version),因为在springboot默认配置中没有设置mybatis框架版本。

2、MyBatis简易配置
我们添加了mybatis依赖后,spring框架启动时会对mybatis进行自动配置。例如SqlSessionFactory工厂对象的创建。想要对mybatis进行简易配置是在文件中进行

配置mybatis中的sql日志的输出:

3、业务分析
基本业务的实现及单元测试

基于Spring对MyBatis框架的整合,实现对商品库中数据的删除操作。

第一步:业务API架构的设计,如图-5所示

springboot hikari连接不释放_Spring Boot 如何整合连接池_java

图-6

业务进阶分析及实现

在MyBatis框架中定义SQL映射的方式有两种:一种是将SQL映射定义在我们的xml映射文件中,一种是借助注解将其声明在接口方法上。我们在实际项目中对于简单的SQL映射可以直接以注解的方式进行声明即可,复杂SQL还是要写到xml中,充分利用动态SQL进行设计会更好些。

三、Spring Boot整合SpringMVC应用

概述

MVC(Model-view-controller)是软件工程中的一种软件架构模式,基于此模式把软件系统分为三个基本部分:模型(Model)、试图(view)和控制器(Controller)。目的是通过这样的设计使程序结构更简洁、直观,降低问题的复杂程度。其中各个组成部分的职责为:

视图(view):–UI设计人员进行图形界面的设计,负责实现与用户交互。
控制器(controller):–负责获取请求,处理请求,响应结果。
模块(model):–实现业务逻辑,数据逻辑。

我们在软件设计时,通常要遵循一定的设计原则。MVC架构迷失的设计中,首先基于单一职责原则让每个对象各司其职。再通过”高内聚,低耦合”的设计思想实现相关对象之间的交互,这样可以更好的提高程序可维护性和可扩展性。

Java EE 技术体系中,MVC设计思想的实现如图所示。

springboot hikari连接不释放_Spring Boot 如何整合连接池_java

图-7

在图7中,Servlet充当MVC中的Controller,负责调用model处理业务,负责转发或重定向到某个页面,在页面上呈现数据。模块封装了对Servlet的技术应用,简化了程序员对请求和响应过程中数据的处理。Spring MVC是Spring框架中基于MVC设计思想实现的一个用于处理Web请求的模块。

以上就是Spring Boot 如何整合连接池的详细内容,更多关于Spring Boot 整合连接池的资料请关注脚本之家其它相关文章!

来源:weixin_39537977

声明:本站部分文章及图片转载于互联网,内容版权归原作者所有,如本站任何资料有侵权请您尽早请联系jinwei@zod.com.cn进行处理,非常感谢!

上一篇 2020年10月1日
下一篇 2020年10月1日

相关推荐