package com.example.demo.config; import com.zaxxer.hikari.HikariDataSource; import lombok.extern.slf4j.Slf4j; import org.apache.ibatis.session.SqlSessionFactory; import org.mybatis.spring.SqlSessionFactoryBean; import org.mybatis.spring.SqlSessionTemplate; import org.springframework.beans.factory.annotation.Qualifier; import org.springframework.boot.context.properties.ConfigurationProperties; import org.springframework.boot.jdbc.DataSourceBuilder; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.Primary; import org.springframework.core.io.support.PathMatchingResourcePatternResolver; import javax.sql.DataSource; @Slf4j @Configuration public class Mysql1DataSourceConfig { // @Bean(name = "mysql1DataSource") //// @Primary // public DataSource mysql1DataSource() { // HikariDataSource dataSource = new HikariDataSource(); // dataSource.setJdbcUrl("jdbc:mysql://54.251.137.151:10701/hwgold?serverTimezone=Asia/Shanghai&useSSL=false&useUnicode=true&characterEncoding=UTF-8"); // dataSource.setUsername("hwgold"); // dataSource.setPassword("AGX4Z3YMxiCG3GR2"); // dataSource.setDriverClassName("com.mysql.cj.jdbc.Driver"); // dataSource.setMaximumPoolSize(10); // dataSource.setPoolName("mysql1HikariCP"); // log.info("mysql1 DataSource initialized with pool-name: {}", dataSource.getPoolName()); // return dataSource; // } @Bean(name = "mysql1DataSource") @ConfigurationProperties(prefix = "spring.datasource.mysql1") public DataSource mysql2DataSource() { return DataSourceBuilder.create().type(HikariDataSource.class).build(); } @Bean(name = "mysql1SqlSessionFactory") // @Primary public SqlSessionFactory mysql1SqlSessionFactory(@Qualifier("mysql1DataSource") DataSource dataSource, @Qualifier("globalConfiguration1") org.apache.ibatis.session.Configuration globalConfiguration1) throws Exception { SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean(); sessionFactory.setDataSource(dataSource); sessionFactory.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath:mapper/*.xml")); sessionFactory.setConfiguration(globalConfiguration1); return sessionFactory.getObject(); } @Bean(name = "mysql1SqlSessionTemplate") // @Primary public SqlSessionTemplate mysql1SqlSessionTemplate(@Qualifier("mysql1SqlSessionFactory") SqlSessionFactory sqlSessionFactory) { return new SqlSessionTemplate(sqlSessionFactory); } @Bean @ConfigurationProperties(prefix = "mybatis.configuration.mysql1") public org.apache.ibatis.session.Configuration globalConfiguration1() { return new org.apache.ibatis.session.Configuration(); } }