spring boot整合mybatis深坑之c3p0的详细配置

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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的连接池就默认集成配置这几个,如果使用别的数据源例如阿里的上面的方法应该也适用

技术分享

 

 

以上是关于spring boot整合mybatis深坑之c3p0的详细配置的主要内容,如果未能解决你的问题,请参考以下文章

Spring Boot整合Mybati之逆向工程

上手spring boot项目之spring boot整合mybatis进行增删改查的三种方式。

spring boot 1.5.4 整合 mybatis

SpringBoot之整合MyBatis

springboot整合数据源mybatis

(56)java Spring Cloud+Spring boot+mybatis企业快速开发架构之Spring Cloud整合Zipkin进行服务跟踪