亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何使用springboot不自動初始化數據庫連接池

發布時間:2021-09-10 13:20:57 來源:億速云 閱讀:289 作者:小新 欄目:開發技術

小編給大家分享一下如何使用springboot不自動初始化數據庫連接池,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

springboot不自動初始化數據庫連接池

簡介

有時候我們想自己動態的初始化數據庫連接池,但是springboot 的@SpringBootApplication注解會自動去初始化數據庫連接池,不配置的話會啟動失敗,如下提示

Exception encountered during context initialization - cancelling refresh attempt: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'dataSource' defined in class path resource [org/springframework/boot/autoconfigure/jdbc/DataSourceConfiguration$Dbcp2.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.commons.dbcp2.BasicDataSource]: Factory method 'dataSource' threw exception; nested exception is org.springframework.boot.autoconfigure.jdbc.DataSourceProperties$DataSourceBeanCreationException: Failed to determine a suitable driver class
INFO - Unregistering JMX-exposed beans on shutdown

解決方案

辦法就是排除自動初始化的類

@SpringBootApplication(exclude = {DataSourceAutoConfiguration.class})
public class Application implements CommandLineRunner {
...
}

加上這么一句

(exclude = {DataSourceAutoConfiguration.class})

就可以跳過數據庫的自動初始化,自己為所欲為了~

記錄下spring boot關于數據庫連接池的一個小坑

環境:spring boot 1.5、JDK1.8

application.properties配置

# 驅動配置信息
spring.datasource.url = jdbc:mysql://127.0.0.1:3306/mealsystem?useUnicode=true&characterEncoding=utf-8
spring.datasource.username = root
spring.datasource.password = 123456
spring.datasource.driverClassName = com.mysql.jdbc.Driver

#連接池的配置信息
spring.datasource.initialSize=5
spring.datasource.minIdle=5
spring.datasource.maxActive=20
spring.datasource.maxWait=60000
spring.datasource.timeBetweenEvictionRunsMillis=60000
spring.datasource.minEvictableIdleTimeMillis=300000
spring.datasource.validationQuery=SELECT 1 FROM DUAL
spring.datasource.testWhileIdle=true
spring.datasource.testOnBorrow=false
spring.datasource.testOnReturn=false
spring.datasource.poolPreparedStatements=true
spring.datasource.maxPoolPreparedStatementPerConnectionSize=20
spring.datasource.filters=stat,wall,log4j
spring.datasource.connectionProperties=druid.stat.mergeSql=true;druid.stat.slowSqlMillis=5000

先找到這個類

org.springframework.boot.autoconfigure.jdbc.DataSourceBuilder

在下面的源碼中打個斷點

public DataSource build() {
        Class<? extends DataSource> type = this.getType();
        DataSource result = (DataSource)BeanUtils.instantiate(type);
        this.maybeGetDriverClassName();
        this.bind(result);
        return result;
    }

啟動項目

如何使用springboot不自動初始化數據庫連接池

我們可以發現,在沒有配置spring.datasource.type時,spring boot默認的連接池是tomcat-jdbc

也就是說我們在application.properties中配置的連接池參數是無效的。

好,那我們再配置下這個屬性,使用阿里巴巴的druid

spring.datasource.type=com.alibaba.druid.pool.DruidDataSource

再啟動下

如何使用springboot不自動初始化數據庫連接池

再來看看1.5版本org.springframework.boot.autoconfigure.jdbc.DataSourceBuilder的源碼

private static final String[] DATA_SOURCE_TYPE_NAMES = new String[] {
            "org.apache.tomcat.jdbc.pool.DataSource",
            "com.zaxxer.hikari.HikariDataSource",
            "org.apache.commons.dbcp.BasicDataSource", // deprecated
            "org.apache.commons.dbcp2.BasicDataSource" };
  • spring boot 1.5的版本默認連接池為tomcat-jdbc

  • spring boot 2.0的版本默認連接池為HikariCP

以上是“如何使用springboot不自動初始化數據庫連接池”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

汉寿县| 玉树县| 冀州市| 绵阳市| 克东县| 宁远县| 康马县| 枣强县| 新宾| 白玉县| 梧州市| 洪洞县| 麟游县| 仁化县| 塘沽区| 广安市| 东宁县| 白朗县| 满城县| 大荔县| 娱乐| 福州市| 黎平县| 疏附县| 育儿| 曲沃县| 右玉县| 乐清市| 侯马市| 马边| 图木舒克市| 东至县| 漠河县| 康平县| 绍兴县| 饶河县| 五原县| 那曲县| 内江市| 文成县| 昭平县|