分库分表ShardingSphere-ShardingJDBC数据分片实战1

系列文章目录

  • MySQL分表分库基础
  • 分库分表-ShardingSphere基础
  • 分库分表ShardingSphere-ShardingJDBC数据分片实战1
  • 分库分表ShardingSphere-ShardingJDBC数据分片实战2
  • 分库分表ShardingSphere-ShardingJDBC源码解析

文章目录

  • 系列文章目录
  • 前言
  • 一、ShardingJDBC概念
  • 二、使用步骤
    • 1.maven 引入
    • 2 规则配置
      • 数据源配置
      • 数据分配策略
        • 标准分片表配置
        • 分表分库策略配置
          • 用于单分片键的标准分片场景
          • 用于多分片键的复合分片场景
          • 用于 Hint 的分片策略
        • 自动分片表配置
        • 分布式序列策略配置
        • 绑定表规则
        • 广播表规则
        • 默认策略
        • 分片算法配置
        • 分布式序列算法配置


前言

前面介绍了ShardingSphere核心概念,本章节主要讲解ShardingJdbc的使用


一、ShardingJDBC概念

  • ShardingJDBC 为Java 的 JDBC 层提供的额外服务
  • 它使⽤客⼾端直连数据库,以 jar
    包形式提供服务,⽆需额外部署和依赖,可理解为增强版的 JDBC 驱动 完全兼容 JDBC 和各种 ORM 框架
  • 分表分库逻辑油业务决定,相对灵活
  • 采用无中心化架构,适合Java开发的高性能OLTP应用
  • 缺点:业务侵入性较大
    分库分表ShardingSphere-ShardingJDBC数据分片实战1_第1张图片

二、使用步骤

1.maven 引入

ShardingSphere-JDBC 可以通过 Java,YAML,Spring 命名空间和 Spring Boot Starter 这 4 种方式进行配置,本文主要介绍用Spring Boot Starter

${shardingsphere.version} 更改为实际的版本号本文使用版本为4.1.1

<dependency>
    <groupId>org.apache.shardingspheregroupId>
    <artifactId>sharding-jdbc-spring-boot-starterartifactId>
    <version>${shardingsphere.version}version>
dependency>


<dependency>
    <groupId>org.apache.shardingspheregroupId>
    <artifactId>sharding-jdbc-spring-namespaceartifactId>
    <version>${shardingsphere.version}version>
dependency>

2 规则配置

数据源配置

spring.shardingsphere.datasource.names= # 真实数据源名称,多个数据源用逗号区分

#  表示真实数据源名称
spring.shardingsphere.datasource.-data-source-name>.type= # 数据库连接池全类名
spring.shardingsphere.datasource.-data-source-name>.driver-class-name= # 数据库驱动类名,以数据库连接池自身配置为准
spring.shardingsphere.datasource.-data-source-name>.jdbc-url= # 数据库 URL 连接,以数据库连接池自身配置为准
spring.shardingsphere.datasource.-data-source-name>.username= # 数据库用户名,以数据库连接池自身配置为准
spring.shardingsphere.datasource.-data-source-name>.password= # 数据库密码,以数据库连接池自身配置为准
spring.shardingsphere.datasource.-data-source-name>.>= # ... 数据库连接池的其它属性

配置示例

# 配置真实数据源
spring.shardingsphere.datasource.names=ds1,ds2

# 配置第 1 个数据源
spring.shardingsphere.datasource.ds1.type=com.zaxxer.hikari.HikariDataSource
spring.shardingsphere.datasource.ds1.driver-class-name=com.mysql.jdbc.Driver
spring.shardingsphere.datasource.ds1.jdbc-url=jdbc:mysql://localhost:3306/ds1
spring.shardingsphere.datasource.ds1.username=root
spring.shardingsphere.datasource.ds1.password=

# 配置第 2 个数据源
spring.shardingsphere.datasource.ds2.type=com.zaxxer.hikari.HikariDataSource
spring.shardingsphere.datasource.ds2.driver-class-name=com.mysql.jdbc.Driver
spring.shardingsphere.datasource.ds2.jdbc-url=jdbc:mysql://localhost:3306/ds2
spring.shardingsphere.datasource.ds2.username=root
spring.shardingsphere.datasource.ds2.password=

数据分配策略

标准分片表配置

spring.shardingsphere.rules.sharding.tables.-name>.actual-data-nodes= 
# 由数据源名 + 表名组成,以小数点分隔。多个表以逗号分隔,支持 inline 表达式。
# 缺省表示使用已知数据源与逻辑表名称生成数据节点,用于广播表(即每个库中都需要一个同样的表用于关联查询,多为字典表)或只分库不分表且所有库的表结构完全一致的情况

分表分库策略配置

用于单分片键的标准分片场景

分表

spring.shardingsphere.rules.sharding.tables.-name>.table-strategy.standard.sharding-column= # 分片列名称
spring.shardingsphere.rules.sharding.tables.-name>.table-strategy.standard.sharding-algorithm-name= # 分片算法名称

分库

spring.shardingsphere.rules.sharding.tables.-name>.database-strategy.standard.sharding-column= # 分片列名称
spring.shardingsphere.rules.sharding.tables.-name>.database-strategy.standard.sharding-algorithm-name= # 分片算法名称
用于多分片键的复合分片场景

分表

spring.shardingsphere.rules.sharding.tables.-name>.table-strategy.complex.sharding-columns= # 分片列名称,多个列以逗号分隔
spring.shardingsphere.rules.sharding.tables.-name>.table-strategy.complex.sharding-algorithm-name= # 分片算法名称

分库

spring.shardingsphere.rules.sharding.tables.-name>.database-strategy.complex.sharding-columns= # 分片列名称,多个列以逗号分隔
spring.shardingsphere.rules.sharding.tables.-name>.database-strategy.complex.sharding-algorithm-name= # 分片算法名称
用于 Hint 的分片策略

分表

spring.shardingsphere.rules.sharding.tables.-name>.table-strategy.hint.sharding-algorithm-name= # 分片算法名称

分库

spring.shardingsphere.rules.sharding.tables.-name>.database-strategy.hint.sharding-algorithm-name= # 分片算法名称

自动分片表配置

spring.shardingsphere.rules.sharding.auto-tables.-table-name>.actual-data-sources= # 数据源名

spring.shardingsphere.rules.sharding.auto-tables.-table-name>.sharding-strategy.standard.sharding-column= # 分片列名称
spring.shardingsphere.rules.sharding.auto-tables.-table-name>.sharding-strategy.standard.sharding-algorithm-name= # 自动分片算法名称

分布式序列策略配置

spring.shardingsphere.rules.sharding.tables.-name>.key-generate-strategy.column= # 分布式序列列名称
spring.shardingsphere.rules.sharding.tables.-name>.key-generate-strategy.key-generator-name= # 分布式序列算法名称

绑定表规则

spring.shardingsphere.rules.sharding.binding-tables[0]= # 绑定表规则列表
spring.shardingsphere.rules.sharding.binding-tables[1]= # 绑定表规则列表
spring.shardingsphere.rules.sharding.binding-tables[x]= # 绑定表规则列表

广播表规则

spring.shardingsphere.rules.sharding.broadcast-tables[0]= # 广播表规则列表
spring.shardingsphere.rules.sharding.broadcast-tables[1]= # 广播表规则列表
spring.shardingsphere.rules.sharding.broadcast-tables[x]= # 广播表规则列表

默认策略

spring.shardingsphere.sharding.default-database-strategy.xxx= # 默认数据库分片策略
spring.shardingsphere.sharding.default-table-strategy.xxx= # 默认表分片策略
spring.shardingsphere.sharding.default-key-generate-strategy.xxx= # 默认分布式序列策略
spring.shardingsphere.sharding.default-sharding-column= # 默认分片列名称

分片算法配置

spring.shardingsphere.rules.sharding.sharding-algorithms.-algorithm-name>.type= # 分片算法类型
spring.shardingsphere.rules.sharding.sharding-algorithms.-algorithm-name>.props.xxx= # 分片算法属性配置

分布式序列算法配置

spring.shardingsphere.rules.sharding.key-generators.-generate-algorithm-name>.type= # 分布式序列算法类型
spring.shardingsphere.rules.sharding.key-generators.-generate-algorithm-name>.props.xxx= # 分布式序列算法属性配置

你可能感兴趣的:(数据库,分布式专题,分库分表,java,spring,boot,mysql)