spring boot整合mybatis深坑之c3p0的詳細配置


項目地址:https://gitee.com/zhangjunqing/spring-boot/tree/master/springboot-mybatis-notice

本人在c3p0數據源整合過程中,需要詳細配置各種參數,但是根據網上的各種資料配置后發現都測試不對

      1 場景重現網上很多數據源的配置都是以下類似方式進行配置的:

 

    2  跟蹤debug查看spring 中的數據源 acquireIncrement的值依然是默認值3

   

  3 只能手動配置數據源

          思路:增加數據源配置類,將spring啟動數據源信息注入到配置類中,生成datasource,配置類如下:

package com.springboot.config;

import javax.annotation.Resource;
import javax.sql.DataSource;

import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.boot.autoconfigure.jdbc.DataSourceBuilder;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Primary;

public class DatasourceConfiguration {
     
     @Bean(name = "dataSource")
     @Qualifier(value = "dataSource")
     @Primary
     @ConfigurationProperties(prefix = "spring.datasource")
     public DataSource dataSource(){
      return DataSourceBuilder.create().type(com.mchange.v2.c3p0.ComboPooledDataSource.class).build();
     }
}                                                                                              

    4  啟動參數如下:

spring:
  datasource:
    jdbcUrl: jdbc:mysql://localhost:3306/test
    user: root
    password: 
    driverClass: com.mysql.jdbc.Driver
    type: com.mchange.v2.c3p0.ComboPooledDataSource
    acquireIncrement: 11
    acquireRetryAttempts: 7

特別注意:此處的配置已經和上面的URL,username等都不一樣了,此處配置的詳情應該參考c3p0中ComboPooledDataSource的參數,類似如下截圖:

  5 進行測試,數據注入正確,並且經過測試事物也正常

  

    6  查看類DataSourceBuilder,發現好像spring的連接池就默認集成配置這幾個,如果使用別的數據源例如阿里的上面的方法應該也適用

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM