Spring Boot 整合连接池

SegmentFault

共 3204字,需浏览 7分钟

 · 2020-11-02

作者:_我姓李

来源:SegmentFault 思否社区




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



图-1


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


通过连接池获取连接的一个基本过程,如图2所示:



图-2


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




一、整合HikariCP连接池


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


第一步:添加依赖。


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


1.mysql数据库驱动依赖。

    mysql    mysql-connector-java    runtime


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

        org.springframework.boot          spring-boot-starter-jdbc




第二步:配置连接池。


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

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




第三步:进行单元测试。


package com.cy.pj.common.datasource;
import java.sql.SQLException;import javax.sql.DataSource;import org.junit.jupiter.api.Test;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.boot.test.context.SpringBootTest;
@SpringBootTestpublic class DataSourceTests {
@Autowired private DataSource dataSource; @Test public void testConnection() throws Exception{ System.out.println(dataSource.getConnection()); }}


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



图-3


在图-3中,演示了我们在测试类DataSourceTests中基于DataSource获取连接的一个基本过程。




二、Spring Boot整合MyBatis框架


MyBatis是一个优秀的持久层框架,底层基于JDBC实现与数据库的交互。并在JDBC操作的基础上做了封装的优化,他借助灵活的SQL定制,参数以及结果集的映射方式,更好的适应了当前互联网技术的发展。MyBatis框架的简单应用框架,如图-4所示:



图-4


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


1、初始配置


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

    
            org.mybatis.spring.boot            mybatis-spring-boot-starter            2.1.1    


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


2、MyBatis简易配置


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


mybatis.configuration.default-statement-timeout=30mybatis.configuration.map-underscore-to-camel-case=true


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


logging.level.com.cy=DEBUG


3、业务分析


基本业务的实现及单元测试


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


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


图-5


第二步:基于id执行商品删除信息,业务时序见图-6


图-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设计思想的实现如图所示。


图-7


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





点击左下角阅读原文,到 SegmentFault 思否社区 和文章作者展开更多互动和交流。

- END -

浏览 7
点赞
评论
收藏
分享

手机扫一扫分享

举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

举报