Spring Boot 如何整合連接池
Spring Boot 整合連接池
在實(shí)際開(kāi)發(fā)中應(yīng)用程序與數(shù)據(jù)庫(kù)交互時(shí),“獲得連接”或在“釋放資源”是非常消耗資源的兩個(gè)過(guò)程,為了解決如此類(lèi)性能問(wèn)題,通常這種情況我們采用連接池技術(shù)重用連接Connection對(duì)象,如圖1所示。
圖-1
其實(shí)Java為數(shù)據(jù)庫(kù)連接池提供了公共的接口:javax.sql.DataSource,各個(gè)廠商需要讓自己的連接池實(shí)現(xiàn)這個(gè)接口。然后我們的應(yīng)用程序中耦合這個(gè)接口,便可以方便的切換不同廠商的連接池,常見(jiàn)的連接池有DBCP、C3P0、DRUID、HikariCP等。
通過(guò)連接池獲取連接的一個(gè)基本過(guò)程,如圖2所示:
圖-2
在圖-2中,用戶先通過(guò)DataSource對(duì)象的getConnection()方法,獲取一個(gè)連接,如果池中有連接,則直接將連接返回給用戶。如果池中沒(méi)有連接,則會(huì)調(diào)用Dirver(驅(qū)動(dòng))對(duì)象的connect方法從數(shù)據(jù)庫(kù)獲取,拿到連接后,可以將連接在連接池中也放一份,然后再將連接返回給調(diào)用用戶。
一、整合HikariCP連接池
HikariCP號(hào)稱(chēng)是目前世界上最快的連接池,有江湖一哥的稱(chēng)號(hào),目前在SpringBoot工程默認(rèn)推薦使用HikariCP連接池。我們?cè)趧?chuàng)建一個(gè)新項(xiàng)目時(shí)步驟如下:
第一步:添加依賴。
編輯項(xiàng)目中的pom.xml,查找MySQL Driver、JDBC API 依賴,依賴添加后,會(huì)在pom.xml文件中自動(dòng)添加如下兩個(gè)依賴配置:
1.mysql數(shù)據(jù)庫(kù)驅(qū)動(dòng)依賴。
<dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <scope>runtime</scope> </dependency>
2.spring對(duì)象jdbc支持(此時(shí)會(huì)默認(rèn)幫我們下載HiKariCP連接池)
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-jdbc</artifactId> </dependency>
第二步:配置連接池。
打開(kāi)application.properties配置文件,添加如下內(nèi)容。
spring.datasource.url=jdbc:mysql:///dbgoods?serverTimezone=GMT%2B8&characterEncoding=utf8 spring.datasource.username=root spring.datasource.password=root
第三步:進(jìn)行單元測(cè)試。
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中,演示了我們?cè)跍y(cè)試類(lèi)DataSourceTests中基于DataSource獲取連接的一個(gè)基本過(guò)程。
二、Spring Boot整合MyBatis框架
MyBatis是一個(gè)優(yōu)秀的持久層框架,底層基于JDBC實(shí)現(xiàn)與數(shù)據(jù)庫(kù)的交互。并在JDBC操作的基礎(chǔ)上做了封裝的優(yōu)化,他借助靈活的SQL定制,參數(shù)以及結(jié)果集的映射方式,更好的適應(yīng)了當(dāng)前互聯(lián)網(wǎng)技術(shù)的發(fā)展。MyBatis框架的簡(jiǎn)單應(yīng)用框架,如圖-4所示:
圖-4
在當(dāng)前互聯(lián)網(wǎng)應(yīng)用項(xiàng)目中,MyBatis框架通常會(huì)由spring框架進(jìn)行資源整合,作為技術(shù)層實(shí)現(xiàn)數(shù)據(jù)交互操作。
1、初始配置
添加mybatis啟動(dòng)依賴
參考mybatis官網(wǎng),找到springboot菜單選項(xiàng)。基于菜單項(xiàng)找到MyBatis啟動(dòng)依賴。
<dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.1.1</version> </dependency>
注意: 在添加此依賴時(shí),一定指定其版本(version),因?yàn)樵趕pringboot默認(rèn)配置中沒(méi)有設(shè)置mybatis框架版本。
2、MyBatis簡(jiǎn)易配置
我們添加了mybatis依賴后,spring框架啟動(dòng)時(shí)會(huì)對(duì)mybatis進(jìn)行自動(dòng)配置。例如SqlSessionFactory工廠對(duì)象的創(chuàng)建。想要對(duì)mybatis進(jìn)行簡(jiǎn)易配置是在application.properties文件中進(jìn)行
mybatis.configuration.default-statement-timeout=30 mybatis.configuration.map-underscore-to-camel-case=true
配置mybatis中的sql日志的輸出:
logging.level.com.cy=DEBUG
3、業(yè)務(wù)分析
基本業(yè)務(wù)的實(shí)現(xiàn)及單元測(cè)試
基于Spring對(duì)MyBatis框架的整合,實(shí)現(xiàn)對(duì)商品庫(kù)中數(shù)據(jù)的刪除操作。
第一步:業(yè)務(wù)API架構(gòu)的設(shè)計(jì),如圖-5所示
圖-5
第二步:基于id執(zhí)行商品刪除信息,業(yè)務(wù)時(shí)序見(jiàn)圖-6
圖-6
業(yè)務(wù)進(jìn)階分析及實(shí)現(xiàn)
在MyBatis框架中定義SQL映射的方式有兩種:一種是將SQL映射定義在我們的xml映射文件中,一種是借助注解將其聲明在接口方法上。我們?cè)趯?shí)際項(xiàng)目中對(duì)于簡(jiǎn)單的SQL映射可以直接以注解的方式進(jìn)行聲明即可,復(fù)雜SQL還是要寫(xiě)到xml中,充分利用動(dòng)態(tài)SQL進(jìn)行設(shè)計(jì)會(huì)更好些。
三、Spring Boot整合SpringMVC應(yīng)用
概述
MVC(Model-view-controller)是軟件工程中的一種軟件架構(gòu)模式,基于此模式把軟件系統(tǒng)分為三個(gè)基本部分:模型(Model)、試圖(view)和控制器(Controller)。目的是通過(guò)這樣的設(shè)計(jì)使程序結(jié)構(gòu)更簡(jiǎn)潔、直觀,降低問(wèn)題的復(fù)雜程度。其中各個(gè)組成部分的職責(zé)為:
視圖(view):--UI設(shè)計(jì)人員進(jìn)行圖形界面的設(shè)計(jì),負(fù)責(zé)實(shí)現(xiàn)與用戶交互。
控制器(controller):--負(fù)責(zé)獲取請(qǐng)求,處理請(qǐng)求,響應(yīng)結(jié)果。
模塊(model):--實(shí)現(xiàn)業(yè)務(wù)邏輯,數(shù)據(jù)邏輯。
我們?cè)谲浖O(shè)計(jì)時(shí),通常要遵循一定的設(shè)計(jì)原則。MVC架構(gòu)迷失的設(shè)計(jì)中,首先基于單一職責(zé)原則讓每個(gè)對(duì)象各司其職。再通過(guò)"高內(nèi)聚,低耦合"的設(shè)計(jì)思想實(shí)現(xiàn)相關(guān)對(duì)象之間的交互,這樣可以更好的提高程序可維護(hù)性和可擴(kuò)展性。
Java EE 技術(shù)體系中,MVC設(shè)計(jì)思想的實(shí)現(xiàn)如圖所示。
圖-7
在圖7中,Servlet充當(dāng)MVC中的Controller,負(fù)責(zé)調(diào)用model處理業(yè)務(wù),負(fù)責(zé)轉(zhuǎn)發(fā)或重定向到某個(gè)頁(yè)面,在頁(yè)面上呈現(xiàn)數(shù)據(jù)。模塊封裝了對(duì)Servlet的技術(shù)應(yīng)用,簡(jiǎn)化了程序員對(duì)請(qǐng)求和響應(yīng)過(guò)程中數(shù)據(jù)的處理。Spring MVC是Spring框架中基于MVC設(shè)計(jì)思想實(shí)現(xiàn)的一個(gè)用于處理Web請(qǐng)求的模塊。
以上就是Spring Boot 如何整合連接池的詳細(xì)內(nèi)容,更多關(guān)于Spring Boot 整合連接池的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Java中PageHelper分頁(yè)后對(duì)list操作導(dǎo)致分頁(yè)無(wú)效
在項(xiàng)目中使用分頁(yè)插件的時(shí)候發(fā)現(xiàn)PageHelper插件失效了,本文就來(lái)介紹一下Java中PageHelper分頁(yè)后對(duì)list操作導(dǎo)致分頁(yè)無(wú)效的解決方法,感興趣的可以了解一下2021-05-05淺談Java基礎(chǔ)知識(shí)之BigDecimal
我們又來(lái)回顧Java基礎(chǔ)知識(shí)啦,今天講的是BigDecimal的基本使用以及異常處理,下文中有非常詳細(xì)的代碼示例以及注釋哦,需要的朋友可以參考下2021-05-05@Configuration與@Component作為配置類(lèi)的區(qū)別詳解
這篇文章主要介紹了@Configuration與@Component作為配置類(lèi)的區(qū)別詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-06-06@PathVariable 如何自動(dòng)填充入實(shí)例對(duì)象中
這篇文章主要介紹了@PathVariable 實(shí)現(xiàn)自動(dòng)填充入實(shí)例對(duì)象中的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-09-09Java從單體架構(gòu)升級(jí)到微服務(wù)要注意的一些問(wèn)題
這篇文章主要介紹了Java從單體架構(gòu)升級(jí)到微服務(wù)要注意的一些問(wèn)題,對(duì)架構(gòu)感興趣的同學(xué),可以參考下2021-04-04Java數(shù)據(jù)結(jié)構(gòu)之實(shí)現(xiàn)跳表
今天帶大家來(lái)學(xué)習(xí)Java數(shù)據(jù)結(jié)構(gòu)的相關(guān)知識(shí),文中對(duì)用Java實(shí)現(xiàn)跳表作了非常詳細(xì)的圖文解說(shuō)及代碼示例,對(duì)正在學(xué)習(xí)java的小伙伴們有很好地幫助,需要的朋友可以參考下2021-05-05用Java編程輸出萬(wàn)年歷的功能實(shí)現(xiàn)
這篇文章主要介紹了用Java編程輸出萬(wàn)年歷的功能實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05Spring中的DeferredImportSelector實(shí)現(xiàn)詳解
這篇文章主要介紹了Spring中的DeferredImportSelector實(shí)現(xiàn)詳解,兩個(gè)官方的實(shí)現(xiàn)類(lèi)AutoConfigurationImportSelector和ImportAutoConfigurationImportSelector都是Spring Boot后新增的實(shí)現(xiàn),需要的朋友可以參考下2024-01-01