springBoot+gradle+Oracle配置Druid

springBoot + gradle 配置Druid数据连接池

首先在build.gradle文件中加入两个依赖:

然后直接在配置文件中,配置需要监控的数据库信息就好了,不需要在application.yml中添加配置,(配置文件需要自己另外新建的)

packagecom.etong.government

importcom.alibaba.druid.pool.DruidDataSource;

importorg.slf4j.Logger;

importorg.slf4j.LoggerFactory

importorg.springframework.context.annotation.Bean;

importorg.springframework.context.annotation.Configuration;

importorg.springframework.context.annotation.Primary;

importjavax.sql.DataSource;

importjava.sql.SQLException;

@Configuration

public classDruidConfig {

private static finalLoggerLOGGER= LoggerFactory.getLogger(DruidConfig.class);

//开发

@Bean(destroyMethod ="close", initMethod ="init")

@Primary

publicDataSource dataSource() {

DruidDataSource datasource =newDruidDataSource();

datasource.setDriverClassName("oracle.jdbc.OracleDriver");

datasource.setUrl("jdbc:oracle:thin:@192.168.10.41:1521:sems");

datasource.setUsername("chargePile");

datasource.setPassword("chargePile");

//其它配置

datasource.setInitialSize(5);

datasource.setMinIdle(5);

datasource.setMaxActive(50);

datasource.setMaxWait(10000);

datasource.setTimeBetweenEvictionRunsMillis(5000);

datasource.setMinEvictableIdleTimeMillis(20000);

datasource.setValidationQuery("SELECT 1 FROM DUAL");

datasource.setTestWhileIdle(true);

datasource.setTestOnBorrow(true);

datasource.setTestOnReturn(false);

datasource.setPoolPreparedStatements(true);

datasource.setMaxPoolPreparedStatementPerConnectionSize(20);

try{

datasource.setFilters("stat,wall,log4j");

}catch(SQLException e) {

LOGGER.error("druid configuration initialization filter", e);

}

returndatasource;

}

@Bean(destroyMethod ="close", initMethod ="init")

publicDataSource dataSource1() {

DruidDataSource datasource =newDruidDataSource();

datasource.setDriverClassName("oracle.jdbc.OracleDriver");

datasource.setUrl("jdbc:oracle:thin:@10.8.20.8:1521:testdb");

datasource.setUsername("cs_wx_db");

datasource.setPassword("cswx");

//其它配置

datasource.setInitialSize(5);

datasource.setMinIdle(5);

datasource.setMaxActive(50);

datasource.setMaxWait(10000);

datasource.setTimeBetweenEvictionRunsMillis(5000);

datasource.setMinEvictableIdleTimeMillis(20000);

datasource.setValidationQuery("SELECT 1 FROM DUAL");

datasource.setTestWhileIdle(true);

datasource.setTestOnBorrow(true);

datasource.setTestOnReturn(false);

datasource.setPoolPreparedStatements(true);

datasource.setMaxPoolPreparedStatementPerConnectionSize(20);

try{

datasource.setFilters("stat,wall,log4j");

}catch(SQLException e) {

LOGGER.error("druid configuration initialization filter", e);

}

returndatasource;

}

}


配置多数据源的区别在于,主数据源多了一个@Primary的注解

主:

从:

你可能感兴趣的:(springBoot+gradle+Oracle配置Druid)