• 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的连接池就默认集成配置这几个,如果使用别的数据源例如阿里的上面的方法应该也适用

     

  • 相关阅读:
    判断一本书是否值得买
    【Python】对我自己的博客进行统计,看看哪年哪月发帖量最大
    在python中使用正则表达式(转载)
    【English】What is a Java StringWriter, and when should I use it?(转帖)
    【Java】利用java.io.PrintWriter写出文本文件
    [MySql]当虚拟机的IP地址自动更换后,JDBC使用原来的配置连不上MySql数据库时所报的异常。
    java中的lastIndexOf( )函数是什么意思
    day63_SpringMVC学习笔记_01
    day62_Mybatis学习笔记_02
    day61_Mybatis学习笔记_01
  • 原文地址:https://www.cnblogs.com/zhangjunqing/p/7707447.html
Copyright © 2020-2023  润新知