Spring Boot 如何整合连接池

Spring Boot 整合连接池

在实际开发中应用程序与数据库交互时,“获得连接”或在“释放资源”是非常消耗资源的两个过程,为了解决如此类性能问题,通常这种情况我们采用连接池技术重用连接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数据库驱动依赖。

<dependency>
 <groupId>mysql</groupId>
 <artifactId>mysql-connector-java</artifactId>
 <scope>runtime</scope>
</dependency>

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

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>

第二步:配置连接池。

打开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;

@SpringBootTest
public 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启动依赖。

 <dependency>
   <groupId>org.mybatis.spring.boot</groupId>
   <artifactId>mybatis-spring-boot-starter</artifactId>
   <version>2.1.1</version>
 </dependency>

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

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

mybatis.configuration.default-statement-timeout=30
mybatis.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请求的模块。

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

(0)

相关推荐

  • Spring Boot ActiveMQ连接池配置过程解析

    spring.activemq.pool.enabled=false时,每发送一条数据都需要创建一个连接,这样会出现频繁创建和销毁连接的场景.为了不踩这个坑,我们参考池化技术的思想,配置ActiveMQ连接池.在Spring Boot ActiveMQ发布/订阅消息模式原理解析的基础上配置ActiveMQ连接池,只需要做两项修改--配置文件和添加连接池依赖. 修改application.properties配置文件 ## URL of the ActiveMQ broker. Auto-gene

  • spring boot配置MySQL数据库连接、Hikari连接池和Mybatis的简单配置方法

    此方法为极简配置,支持MySQL数据库多库连接.支持Hikari连接池.支持MyBatis(包括Dao类和xml文件位置的配置). 1.pom.xml中引入依赖: <!-- Begin of DB related --> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId>

  • SpringBoot开发案例之配置Druid数据库连接池的示例

    前言 好久没有更新Spring Boot系列文章,你说忙么?也可能是,前段时间的关注点也许在其他方面了,最近项目中需要开发小程序,正好采用Spring Boot实现一个后端服务,后面会把相关的代码案例分享出来,不至于大家做小程序后端服务的时候一头雾水. 在Spring Boot下默认提供了若干种可用的连接池(dbcp,dbcp2, tomcat, hikari),当然并不支持Druid,Druid来自于阿里系的一个开源连接池,它提供了非常优秀的监控功能,下面跟大家分享一下如何与Spring Bo

  • Spring boot整合连接池实现过程图解

    整合连接池HiKariCP HiKariCP号称是目前世界上最快的连接池,有江湖一哥的称号,目前在springboot工程默认推荐使用HiKariCP连接池,现在我们创建一个新的项目, 项目名为CGB-SBOOT-02,在此工程中整合HiKariCP,其步骤如下: 第一步:添加依赖. 1>创建项目时添加 2> 编辑项目中pom.xml,右键项目的pom.xml文件,选择spring 查找mysql 驱动依赖,JDBC API依赖 依赖添加以后,在pom.xml文件中会自动添加如下两个依赖配置:

  • spring boot配置druid连接池的完整步骤

    Druid的简介 Druid首先是一个数据库连接池.Druid是目前最好的数据库连接池,在功能.性能.扩展性方面,都超过其他数据库连接池,包括DBCP.C3P0.BoneCP.Proxool.JBoss DataSource.Druid已经在阿里巴巴部署了超过600个应用,经过一年多生产环境大规模部署的严苛考验.Druid是阿里巴巴开发的号称为监控而生的数据库连接池! Druid的功能 1.替换DBCP和C3P0.Druid提供了一个高效.功能强大.可扩展性好的数据库连接池. 2.可以监控数据库

  • Spring Boot如何使用HikariCP连接池详解

    前言 Springboot让Java开发更加美好,更加简洁,更加简单.Spring Boot 2.x中使用HikariCP作为默认的数据连接池. HikariCP使用Javassist字节码操作库来实现动态代理,优化并精简了字节码,同时内部使用 com.zaxxer.hikari.util.FastList 代替ArrayList.使用了更好的并发集合类 com.zaxxer.hikari.util.ConcurrentBag ,"号称"是目前最快的数据库连接池. 下面话不多说了,来一

  • Spring Boot使用Druid连接池的示例代码

    Druid是Java语言中最好的数据库连接池.Druid相比于其他的数据库连接池,有两大特性: 监控数据库,有利于分析线上数据库问题 更容易扩展,同时也很高效. 今天演示一下Spring Boot集成Druid. 实战 1.添加Maven依赖. Spring Boot版本使用的是1.x的,2.x的版本druid starter还不支持.不过自定义也是没问题的. <!--starter-web 方便我们查看效果--> <dependency> <groupId>org.s

  • springboot2.0使用Hikari连接池的方法(替换druid)

    1.springboot 2.0 默认连接池就是Hikari了,所以引用parents后不用专门加依赖 2.贴我自己的配置(时间单位都是毫秒) # jdbc_config datasource spring.datasource.driver-class-name=com.mysql.jdbc.Driver spring.datasource.url=jdbc:mysql://127.0.0.1:3306/datebook?useUnicode=true&characterEncoding=UT

  • springboot配置druid连接池的方法示例

    Druid的简介 Druid首先是一个数据库连接池.Druid是目前最好的数据库连接池,在功能.性能.扩展性方面,都超过其他数据库连接池,包括DBCP.C3P0.BoneCP.Proxool.JBoss DataSource.Druid已经在阿里巴巴部署了超过600个应用,经过一年多生产环境大规模部署的严苛考验.Druid是阿里巴巴开发的号称为监控而生的数据库连接池! Druid的功能 1.替换DBCP和C3P0.Druid提供了一个高效.功能强大.可扩展性好的数据库连接池. 2.可以监控数据库

  • 详解Spring Boot Mysql 版本驱动连接池方案选择

    国内环境下,用Mysql还是比较多的.这里简单的总结了一下,如有缪误,还请指正. Mysql.connect 引入mysql-connector-java包,协议为GPL2.0,该协议具有传染性,即:一旦使用(调用)GPL的库,你的软件将被感染为GPL的软件(主程序).完全不具有商业友好特性.如果有顾虑,可以使用mariadb-java-client进行替代,见mariadb-connector-j,路径是org.mariadb.jdbc.Driver 引入JDBC驱动程序 <dependenc

  • Spring Boot中使用MongoDB的连接池配置的方法

    因为今天开发遇到了性能问题,可能与MongoDB的连接有关,所以稍稍深入看了一下,正好搜到原来有人写过这篇相关的内容,所以转载过来.回头有时间可以写个扩展到SpringForAll里,主体思路还是一样的.感谢这位美女程序媛的文章! 说明 Spring Boot中通过依赖 spring-boot-starter-data-mongodb ,来实现 spring-data-mongodb 的自动配置. 但是默认情况下,Spring Boot 中,并没有像使用MySQL或者Redis一样,提供了连接池

  • SpringBoot整合Druid数据库连接池的方法

    一,Druid是什么? Druid是Java语言中最好的数据库连接池.Druid能够提供强大的监控和扩展功能. 二, 在哪里下载druid maven中央仓库: http://central.maven.org/maven2/com/alibaba/druid/ 三, 怎么获取Druid的源码 Druid是一个开源项目,源码托管在github上,源代码仓库地址是 https://github.com/alibaba/druid.同时每次Druid发布正式版本和快照的时候,都会把源码打包,你可以从

随机推荐