1. 구성 파일
JDK 환경: 1.8은 이중 데이터 소스 springboot+druid+pgsql로 구성되었으며 application.properties 구성은 다음과 같이 수정되었습니다.
#当前入库主数据库
spring.primary.datasource.type=com.alibaba.druid.pool.DruidDataSource
spring.primary.datasource.driver-class-name=org.postgresql.Driver
spring.primary.datasource.url=jdbc:postgresql://localhost:5432/testdb
spring.primary.datasource.username=postgres
spring.primary.datasource.password=postgres
#
#从数据库
spring.secondary.datasource.type=com.alibaba.druid.pool.DruidDataSource
spring.secondary.datasource.driver-class-name=org.postgresql.Driver
spring.secondary.datasource.url=jdbc:postgresql://localhost:5432/postgres
spring.secondary.datasource.username=postgres
spring.secondary.datasource.password=postgres
spring.datasource.druid.initial-size=5
spring.datasource.druid.min-idle=5
spring.datasource.druid.max-active=20
2. 새로운 Java 코드 구성
메인 데이터베이스 인젝션
/**
* @Author yang
* @Date 2023/2/20 11:10
* @Version 1.0
*/
import com.alibaba.druid.pool.DruidDataSource;
import org.apache.ibatis.session.SqlSessionFactory;
import org.mybatis.spring.SqlSessionFactoryBean;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.beans.factory.annotation.Value;
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 org.springframework.jdbc.datasource.DataSourceTransactionManager;
import javax.sql.DataSource;
@Configuration
@MapperScan(basePackages = MasterDataSourceConfig.PACKAGE, sqlSessionFactoryRef = "masterSqlSessionFactory")
public class MasterDataSourceConfig {
// 精确到master目录,以便跟其他数据源隔离
static final String PACKAGE = "com.xx.dao.master";
static final String MAPPER_LOCATION = "classpath*:com/xx/mapper/master/*.xml";
@Value("${spring.primary.datasource.url}")
private String url;
@Value("${spring.primary.datasource.username}")
private String user;
@Value("${spring.primary.datasource.password}")
private String password;
@Value("${spring.primary.datasource.driver-class-name}")
private String driverClass;
private SqlSessionFactory mSessionFactory;
@Bean(name = "masterDataSource")
@Primary
public DataSource masterDataSource() {
DruidDataSource dataSource = new DruidDataSource();
dataSource.setDriverClassName(driverClass);
dataSource.setUrl(url);
dataSource.setUsername(user);
dataSource.setPassword(password);
return dataSource;
}
@Bean(name = "masterTransactionManager")
@Primary
public DataSourceTransactionManager masterTransactionManager() {
return new DataSourceTransactionManager(masterDataSource());
}
@Bean(name = "masterSqlSessionFactory")
@Primary
public SqlSessionFactory masterSqlSessionFactory(@Qualifier("masterDataSource") DataSource masterDataSource)
throws Exception {
final SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean();
sessionFactory.setDataSource(masterDataSource);
sessionFactory.setMapperLocations(new PathMatchingResourcePatternResolver()
.getResources(MasterDataSourceConfig.MAPPER_LOCATION));
//开启驼峰
sessionFactory.getObject().getConfiguration().setMapUnderscoreToCamelCase(true);
this.mSessionFactory = sessionFactory.getObject();
return sessionFactory.getObject();
}
/**
* 获取主库 SessionFactory
* @return
*/
public SqlSessionFactory getMSessionFactory(){
return mSessionFactory;
}
}
데이터베이스 Java 코드에서:
/**
* @Author yang
* @Date 2023/2/20 11:52
* @Version 1.0
*/
@Configuration
// 扫描 Mapper 接口并容器管理
@MapperScan(basePackages = SecondDataSourceConfig.PACKAGE, sqlSessionFactoryRef = "secondSqlSessionFactory")
public class SecondDataSourceConfig {
//精确到第二个数据库目录,以便跟其他数据源隔离
static final String PACKAGE = "com.xx.dao.second";
static final String MAPPER_LOCATION = "classpath*:com/xx/mapper/second/*.xml";
@Value("${spring.secondary.datasource.url}")
private String url;
@Value("${spring.secondary.datasource.username}")
private String user;
@Value("${spring.secondary.datasource.password}")
private String password;
@Value("${spring.secondary.datasource.driver-class-name}")
private String driverClass;
@Bean(name = "secondDataSource")
public DataSource clusterDataSource() {
DruidDataSource dataSource = new DruidDataSource();
dataSource.setDriverClassName(driverClass);
dataSource.setUrl(url);
dataSource.setUsername(user);
dataSource.setPassword(password);
return dataSource;
}
@Bean(name = "secondTransactionManager")
public DataSourceTransactionManager clusterTransactionManager() {
return new DataSourceTransactionManager(clusterDataSource());
}
@Bean(name = "secondSqlSessionFactory")
public SqlSessionFactory clusterSqlSessionFactory(@Qualifier("secondDataSource") DataSource clusterDataSource)
throws Exception {
final SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean();
sessionFactory.setDataSource(clusterDataSource);
sessionFactory.setMapperLocations(new PathMatchingResourcePatternResolver()
.getResources(SecondDataSourceConfig.MAPPER_LOCATION));
//开启驼峰
sessionFactory.getObject().getConfiguration().setMapUnderscoreToCamelCase(true);
return sessionFactory.getObject();
}
}
3. 매퍼 인터페이스, mybatis/xml 파일 구성
여기에 코드를 하나씩 게시하지는 않겠습니다. 가장 중요한 것은 인터페이스가 mybatis xml 구성 파일에 해당한다는 것입니다. 프로젝트 파일 인터페이스는 다음과 같습니다:
dao 인터페이스, Java 데이터 소스 구성 및 mybatis 매핑 파일인 위의 디렉터리를 생성하면 됩니다.
4. 사용방법
위의 구성 파일과 코드를 통해 두 개의 데이터 소스를 구분하였으며, 정상적으로 접속 코드를 직접 사용하실 수 있습니다.예를 들어 dao에서 testClass를 생성하는 작업은
void insert(테스트 테스트), void delete(), @Autowired 주석을 통해 Controller 레이어를 사용할 수 있습니다.
여기서 수정 사항에 주의를 기울여야 합니다.
@MapperScan 내부의 basePackages
MAPPER_LOCATION 변수 구성. 여기서는 주로 다양한 데이터 소스 구성에 대해 다양한 mybatis 구성 파일을 검색합니다.