金币系统后端
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

62 lines
2.8 KiB

4 weeks ago
  1. package com.example.demo.config;
  2. import com.zaxxer.hikari.HikariDataSource;
  3. import lombok.extern.slf4j.Slf4j;
  4. import org.apache.ibatis.session.SqlSessionFactory;
  5. import org.mybatis.spring.SqlSessionFactoryBean;
  6. import org.mybatis.spring.SqlSessionTemplate;
  7. import org.springframework.beans.factory.annotation.Qualifier;
  8. import org.springframework.boot.context.properties.ConfigurationProperties;
  9. import org.springframework.boot.jdbc.DataSourceBuilder;
  10. import org.springframework.context.annotation.Bean;
  11. import org.springframework.context.annotation.Configuration;
  12. import org.springframework.context.annotation.Primary;
  13. import org.springframework.core.io.support.PathMatchingResourcePatternResolver;
  14. import javax.sql.DataSource;
  15. @Slf4j
  16. @Configuration
  17. public class Mysql1DataSourceConfig {
  18. // @Bean(name = "mysql1DataSource")
  19. //// @Primary
  20. // public DataSource mysql1DataSource() {
  21. // HikariDataSource dataSource = new HikariDataSource();
  22. // dataSource.setJdbcUrl("jdbc:mysql://54.251.137.151:10701/hwgold?serverTimezone=Asia/Shanghai&useSSL=false&useUnicode=true&characterEncoding=UTF-8");
  23. // dataSource.setUsername("hwgold");
  24. // dataSource.setPassword("AGX4Z3YMxiCG3GR2");
  25. // dataSource.setDriverClassName("com.mysql.cj.jdbc.Driver");
  26. // dataSource.setMaximumPoolSize(10);
  27. // dataSource.setPoolName("mysql1HikariCP");
  28. // log.info("mysql1 DataSource initialized with pool-name: {}", dataSource.getPoolName());
  29. // return dataSource;
  30. // }
  31. @Bean(name = "mysql1DataSource")
  32. @ConfigurationProperties(prefix = "spring.datasource.mysql1")
  33. public DataSource mysql2DataSource() {
  34. return DataSourceBuilder.create().type(HikariDataSource.class).build();
  35. }
  36. @Bean(name = "mysql1SqlSessionFactory")
  37. // @Primary
  38. public SqlSessionFactory mysql1SqlSessionFactory(@Qualifier("mysql1DataSource") DataSource dataSource,
  39. @Qualifier("globalConfiguration1") org.apache.ibatis.session.Configuration globalConfiguration1) throws Exception {
  40. SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean();
  41. sessionFactory.setDataSource(dataSource);
  42. sessionFactory.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath:mapper/*.xml"));
  43. sessionFactory.setConfiguration(globalConfiguration1);
  44. return sessionFactory.getObject();
  45. }
  46. @Bean(name = "mysql1SqlSessionTemplate")
  47. // @Primary
  48. public SqlSessionTemplate mysql1SqlSessionTemplate(@Qualifier("mysql1SqlSessionFactory") SqlSessionFactory sqlSessionFactory) {
  49. return new SqlSessionTemplate(sqlSessionFactory);
  50. }
  51. @Bean
  52. @ConfigurationProperties(prefix = "mybatis.configuration.mysql1")
  53. public org.apache.ibatis.session.Configuration globalConfiguration1() {
  54. return new org.apache.ibatis.session.Configuration();
  55. }
  56. }