spring boot整合mybatis深坑之c3p0的詳細配置
阿新 • • 發佈:2017-10-22
text context ati reat source ast type fig oot
項目地址: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的連接池就默認集成配置這幾個,如果使用別的數據源例如阿裏的上面的方法應該也適用
spring boot整合mybatis深坑之c3p0的詳細配置