spring boot 在配置時作了不少簡化配置的設置,可是簡化的配置每每已犧牲必定的定製化,好比在數據源的配置時,spring boot 只提供4種數據庫鏈接池的配置,其中並不支持經常使用的druidmysql
閱讀spring boot DataSourceBuilder 的源碼能夠發現 spring boot 提供的4種數據源類型並非咱們想要的spring
private static final String[] DATA_SOURCE_TYPE_NAMES = new String[] { "org.apache.tomcat.jdbc.pool.DataSource", "com.zaxxer.hikari.HikariDataSource", "org.apache.commons.dbcp.BasicDataSource", // deprecated "org.apache.commons.dbcp2.BasicDataSource" };
可是 DataSourceBuilder 提供了type方法來自定義DataSource類型sql
public DataSourceBuilder type(Class<? extends DataSource> type) { this.type = type; return this; }
知道了方法,下面配置就簡單許多了數據庫
首先是application.properties 文件的配置apache
spring.datasource.sso.url=jdbc:mysql://localhost:3306/sso?useSSL=false spring.datasource.sso.username=root spring.datasource.sso.password=root spring.datasource.sso.driver-class-name=com.mysql.jdbc.Driver spring.datasource.sso.max-idle=5 spring.datasource.sso.max-wait=10000 spring.datasource.sso.min-idle=1 spring.datasource.sso.initial-size=1 spring.datasource.sso.validation-query=SELECT 1 spring.datasource.sso.test-on-borrow=false spring.datasource.sso.test-while-idle=true spring.datasource.sso.time-between-eviction-runs-millis=18800 spring.datasource.message.url=jdbc:mysql://localhost:3306/message?useSSL=false spring.datasource.message.username=root spring.datasource.message.password=root spring.datasource.message.driver-class-name=com.mysql.jdbc.Driver spring.datasource.message.max-idle=5 spring.datasource.message.max-wait=10000 spring.datasource.message.min-idle=1 spring.datasource.message.initial-size=1 spring.datasource.message.validation-query=SELECT 1 spring.datasource.message.test-on-borrow=false spring.datasource.message.test-while-idle=true spring.datasource.message.time-between-eviction-runs-millis=18800
而後是具體的主數據源配置類tomcat
@Configuration @MapperScan(basePackages = {"org.vergil.demo.core.dao.mapper.sso"}, sqlSessionFactoryRef = "ssoSqlSessionFactory") public class SsoConfig { @Bean(name = "ssoDataSource") @ConfigurationProperties(prefix = "spring.datasource.sso") @Primary public DataSource ssoDataSource() { //指定使用DruidDataSource return DataSourceBuilder.create().type(com.alibaba.druid.pool.DruidDataSource.class).build(); } @Bean(name = "ssoSqlSessionFactory") @Primary public SqlSessionFactory testSqlSessionFactory(@Qualifier("ssoDataSource") DataSource dataSource) throws Exception { SqlSessionFactoryBean bean = new SqlSessionFactoryBean(); bean.setDataSource(dataSource); // bean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath:mapper/sso/*.xml")); return bean.getObject(); } @Primary @Bean(name = "ssoTransactionManager") public DataSourceTransactionManager testTransactionManager(@Qualifier("ssoDataSource") DataSource dataSource) { return new DataSourceTransactionManager(dataSource); } @Primary @Bean(name = "ssoSqlSessionTemplate") public SqlSessionTemplate testSqlSessionTemplate(@Qualifier("ssoSqlSessionFactory") SqlSessionFactory sqlSessionFactory) throws Exception { return new SqlSessionTemplate(sqlSessionFactory); }
_ @ConfigurationProperties(prefix = "spring.datasource.sso") 引入配置項_app
使用以下方式來建立DruidDataSource,簡化配置ui
return DataSourceBuilder.create().type(com.alibaba.druid.pool.DruidDataSource.class).build();
第二數據源this
@Configuration @MapperScan(basePackages = {"org.vergil.demo.core.dao.mapper.message"}, sqlSessionFactoryRef = "messageSqlSessionFactory") public class MessageConfig { @Bean(name = "messageDataSource") @ConfigurationProperties(prefix = "spring.datasource.message") public DataSource messageDataSource() { return DataSourceBuilder.create().type(com.alibaba.druid.pool.DruidDataSource.class).build(); } @Bean(name = "messageSqlSessionFactory") public SqlSessionFactory testSqlSessionFactory(@Qualifier("messageDataSource") DataSource dataSource) throws Exception { SqlSessionFactoryBean bean = new SqlSessionFactoryBean(); bean.setDataSource(dataSource); // bean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath:mapper/message/*.xml")); return bean.getObject(); } @Bean(name = "messageTransactionManager") public DataSourceTransactionManager testTransactionManager(@Qualifier("messageDataSource") DataSource dataSource) { return new DataSourceTransactionManager(dataSource); } @Bean(name = "messageSqlSessionTemplate") public SqlSessionTemplate testSqlSessionTemplate(@Qualifier("messageSqlSessionFactory") SqlSessionFactory sqlSessionFactory) throws Exception { return new SqlSessionTemplate(sqlSessionFactory); } }
數據源配置完畢url
每一個數據源都會生成本身的sqlSession,相互獨立