>  기사  >  Java  >  Spring Boot에서 Sharding-JDBC 읽기 및 쓰기 분리 통합 소개(코드 포함)

Spring Boot에서 Sharding-JDBC 읽기 및 쓰기 분리 통합 소개(코드 포함)

不言
不言앞으로
2019-03-12 15:46:332977검색

이 기사에서는 Spring Boot의 Sharding-JDBC 읽기 및 쓰기 분리 통합에 대해 소개합니다(코드 포함). 필요한 친구가 참고할 수 있기를 바랍니다. . 돕다.

이전에는 XML을 사용하여 데이터 소스 구성, 읽기-쓰기 분리 전략, 하위 데이터베이스 및 하위 테이블 전략 등을 구성했습니다. 이미 사용하고 있기 때문에 일부 친구도 이전에 Spring Boot 방식이 있는지 물어봤습니다. Spring Boot에서는 XML도 사용합니다. 구성이 약간 일관성이 없는 것 같습니다.

사실 개인적으로 사용하기 쉽고, 읽기 쉽고, 이해하기 쉽다면 마이바티스의 SQL도 XML로 작성되는 것 아닌가?

오늘은 Spring Boot 방식의 사용법을 소개하겠습니다. 주로 읽기와 쓰기 분리 구성을 설명하고 나머지는 나중에 소개하겠습니다.

스프링 부트(Spring Boot) 방식은 위에서 언급한 정보를 속성 파일이나 YAML 파일을 통해 직접 구성하는 방식입니다.

주로 shardingjdbc에서 제공하는 스타터를 사용하며 구성은 다음과 같습니다.

<dependency>
    <groupId>io.shardingjdbc</groupId>
    <artifactId>sharding-jdbc-spring-boot-starter</artifactId>
    <version>2.0.0.M3</version>
</dependency>

구성 내용은 다음과 같습니다.

server.port=8084

mybatis.config-location=classpath:META-INF/mybatis-config.xml

sharding.jdbc.datasource.names=ds_master,ds_slave

# 主数据源
sharding.jdbc.datasource.ds_master.type=com.alibaba.druid.pool.DruidDataSource
sharding.jdbc.datasource.ds_master.driver-class-name=com.mysql.jdbc.Driver
sharding.jdbc.datasource.ds_master.url=jdbc:mysql://localhost:3306/ds_0?characterEncoding=utf-8
sharding.jdbc.datasource.ds_master.username=root
sharding.jdbc.datasource.ds_master.password=123456

# 从数据源
sharding.jdbc.datasource.ds_slave.type=com.alibaba.druid.pool.DruidDataSource
sharding.jdbc.datasource.ds_slave.driver-class-name=com.mysql.jdbc.Driver
sharding.jdbc.datasource.ds_slave.url=jdbc:mysql://localhost:3306/ds_1?characterEncoding=utf-8
sharding.jdbc.datasource.ds_slave.username=root
sharding.jdbc.datasource.ds_slave.password=123456

# 读写分离配置
sharding.jdbc.config.masterslave.load-balance-algorithm-type=round_robin
sharding.jdbc.config.masterslave.name=dataSource
sharding.jdbc.config.masterslave.master-data-source-name=ds_master
sharding.jdbc.config.masterslave.slave-data-source-names=ds_slave
  • sharding.jdbc.config.masterslave.load-balance-algorithm-type

로드 밸런싱 쿼리 중 알고리즘은 현재 round_robin(폴링)과 무작위(random)의 2가지 알고리즘이 있으며, 알고리즘 인터페이스는 io.shardingjdbc.core.api.algorithm.masterslave.MasterSlaveLoadBalanceAlgorithm입니다. 구현 클래스에는 RandomMasterSlaveLoadBalanceAlgorithm 및 RoundRobinMasterSlaveLoadBalanceAlgorithm이 포함됩니다.

  • sharding.jdbc.config.masterslave.master-data-source-name

마스터 데이터 소스 이름

  • sharding.jdbc.config.masterslave.slave-data-source-names

슬레이브 데이터 소스 이름 , 여러 개를 쉼표로 구분하세요

이렇게 간단합니다. 다음은 읽기 및 쓰기 분리 효과를 테스트하는 코드입니다. 여기서는 코드를 사용하지 않겠습니다. 기사에 게시하면 모두가 그럴 것입니다.


위 내용은 Spring Boot에서 Sharding-JDBC 읽기 및 쓰기 분리 통합 소개(코드 포함)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 segmentfault.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제