[后端]springboot整合shardingSphere-JDBC读写分离

在此之前需要搭建mysql集群,可以看看下面两篇文章,随意选择一个搭建即可。

[Mysql8.0主从复制]-CSDN博客

官方文档地址:ShardingSphere

选择自己的版本,我选的是5.1.1 

1.引入依赖

    <dependencies>
        <!--测试相关依赖-->
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-test</artifactId>
            <version>5.3.19</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-test</artifactId>
            <version>2.5.12</version>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <!--sharding依赖-->
        <dependency>
            <groupId>org.apache.shardingsphere</groupId>
            <artifactId>shardingsphere-jdbc-core-spring-boot-starter</artifactId>
            <version>5.1.1</version>
        </dependency>

        <!-- Mybatis -->
        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>2.1.1</version>
        </dependency>
        <!-- mysql       -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.23</version>
            <scope>runtime</scope>
        </dependency>
    </dependencies>

2.在写数据库建表

create table user
(
    id   int          not null
        primary key,
    name varchar(255) not null
);

 3.实体类

public class User {
    private String name;

    private int id;

    public User() {
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }
}

4.mapper

public interface UserMapper {

    @Insert("INSERT INTO user (id,name) values (#{id},#{name})")
    int insert(User record);

    @Select("SELECT * from user")
    List<User> selectByPrimaryKey();

}

5.配置文件(yml格式)

spring:
  shardingsphere:
    mode:
      type: Memory # 有集群,单机,内存。自己学习用内存模式即可
    datasource:
      names: master,slave0,slave1 #每个数据源的名称
      master:
        type: com.zaxxer.hikari.HikariDataSource
        driver-class-name: com.mysql.cj.jdbc.Driver
        url: jdbc:mysql://192.168.6.128:9906/test?allowPublicKeyRetrieval=true
        username: root
        password: 123456
      slave0:
        type: com.zaxxer.hikari.HikariDataSource
        driver-class-name: com.mysql.cj.jdbc.Driver
        url: jdbc:mysql://192.168.6.128:9907/test?allowPublicKeyRetrieval=true
        username: root
        password: 123456
      slave1:
        type: com.zaxxer.hikari.HikariDataSource
        driver-class-name: com.mysql.cj.jdbc.Driver
        url: jdbc:mysql://192.168.6.128:9908/test?allowPublicKeyRetrieval=true
        username: root
        password: 123456
    rules:
        readwrite-splitting: #读写分离规则
          data-sources:
            ms: # 自定义名称,随便写
              type: Static #因为上面配置的数据库信息是死的,所以是Static
              props:
                write-data-source-name: master #写的数据源名称
                read-data-source-names: slave0,slave1 #读的数据眼名称
              load-balancer-name: round-robin # 自定义负载均衡算法名称
          load-balancers:
            round-robin: # 和自己写的自定义负载均衡算法名称一致
              type: ROUND_ROBIN  # 负载均衡算法类型,看文档选自己喜欢的
    props:
      sql-show: true # 显示Sql

6.测试类

@RunWith(SpringRunner.class)
@SpringBootTest(classes = Sharding.class, webEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT) //classes是主类的启动名称
public class MyTest {
    @Autowired
    UserMapper userMapper;
    @Test
    public void saveGet() {
        User user = new User();
        user.setId(3);
        user.setName("测试");
        List<User> users = userMapper.selectByPrimaryKey();
        System.out.println("插入前user表大小:"+users.size());
        userMapper.insert(user);
        List<User> users1 = userMapper.selectByPrimaryKey();
        System.out.println("插入后user表大小:"+users1.size());
    }
}

7.测试结果

  • 5
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
ShardingSphere:SpringBoot2+MybatisPlus+读写分离+分库分表课程目标快速的掌握读写分离+分表的实战,即插即用适用人群IT从业人员,开发人员,Java从业者,互联网从业者,性能调优人群课程简介ShardingSphere是一套开源的分布式数据库中间件解决方案组成的生态圈。它由Sharding-JDBCSharding-Proxy和Sharding-Sidecar(计划中)这3款相互独立的产品组成,shardingSphere定位为关系型数据库中间件。 Sharding-JDBCSharding-JDBCSharding-Sphere的第一个产品,也是Sharding-Sphere的前身,是当当网开源的一个产品。定位为轻量级的Java框架,在JavaJDBC层提供额外服务。 它使用客户端直连数据库,以jar包形式提供服务,无需额外部署和依赖,可理解为增强版的JDBC驱动,完全兼容JDBC和各种ORM框架。他们均提供标准化的数据分片、读写分离、柔性事务和数据治理功能,可适用于如Java同构、异构语言、容器、云原生等各种多样化的应用场景。Sharding-JDBC可以通过Java,YAML,Spring命名空间和Spring Boot Starter四种方式配置,开发者可根据场景选择适合的配置方式。课程特色 本章节以尽量短的时间,为使用者提供最简单的ShardingSphere的快速入门。课程说明该课程属于系列课程,分为读写分离,分库不分表,不分库分表,分库分表,读写分离+分库分表共5个回合。本课程属于其中一个回合,请各位小哥哥们注意,课程的标题哦~

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值