shardingsphere实现数据库读写分离

实验环境:

主数据库:userdb_master

从数据库:userdb_slave0,userdb_slave1

数据库各有一个表user

shardingsphere版本:4.0.0-RC3

实验没有实现数据库的主从同步,只是建了数据库叫从库。

第一步:建立数据库表

在userdb_master,userdb_slave0,userdb_slave1各建立一张表user

CREATE TABLE `user` (
  `id` bigint(255) NOT NULL AUTO_INCREMENT,
  `name` varchar(255) DEFAULT NULL,
  `uid` varchar(255) DEFAULT NULL,
  `school` varchar(255) DEFAULT NULL,
  `age` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`)
)

第二步:springboot项目中引入shardingsphere,注意要引入两个包

<!-- for spring boot -->
<dependency>
     <groupId>org.apache.shardingsphere</groupId>
      <artifactId>sharding-jdbc-spring-boot-starter</artifactId>
      <version>4.0.0-RC3</version>
 </dependency>

<!-- for spring namespace -->
 <dependency>
      <groupId>org.apache.shardingsphere</groupId>
      <artifactId>sharding-jdbc-spring-namespace</artifactId>
      <version>4.0.0-RC3</version>
 </dependency>

第三步:配置application.properties

#读写分离配置,即一主多从方式配置
debug=false
server.port=8082
server.servlet.context-path=
spring.jackson.serialization.INDENT_OUTPUT=true
spring.profiles.active=
#spring.main.allow-bean-definition-overriding=true

spring.shardingsphere.datasource.names=db-master-user,db-slave-user,db-slave1-user

spring.shardingsphere.datasource.db-master-user.type=com.zaxxer.hikari.HikariDataSource
spring.shardingsphere.datasource.db-master-user.driver-class-name=com.mysql.jdbc.Driver
spring.shardingsphere.datasource.db-master-user.jdbc-url=jdbc:mysql://youripaddress:3306/userdb_master?characterEncoding=utf-8&serverTimezone=UTC
spring.shardingsphere.datasource.db-master-user.username=
spring.shardingsphere.datasource.db-master-user.password=

spring.shardingsphere.datasource.db-slave-user.type=com.zaxxer.hikari.HikariDataSource
spring.shardingsphere.datasource.db-slave-user.driver-class-name=com.mysql.jdbc.Driver
spring.shardingsphere.datasource.db-slave-user.jdbc-url=jdbc:mysql://youripaddress:3306/userdb_slave0?characterEncoding=utf-8&serverTimezone=UTC
spring.shardingsphere.datasource.db-slave-user.username=
spring.shardingsphere.datasource.db-slave-user.password=

spring.shardingsphere.datasource.db-slave1-user.type=com.zaxxer.hikari.HikariDataSource
spring.shardingsphere.datasource.db-slave1-user.driver-class-name=com.mysql.jdbc.Driver
spring.shardingsphere.datasource.db-slave1-user.jdbc-url=jdbc:mysql://youripaddress:3306/userdb_slave1?characterEncoding=utf-8&serverTimezone=UTC
spring.shardingsphere.datasource.db-slave1-user.username=
spring.shardingsphere.datasource.db-slave1-user.password=

spring.shardingsphere.masterslave.load-balance-algorithm-type=round_robin
spring.shardingsphere.masterslave.name=ds_ms
spring.shardingsphere.masterslave.master-data-source-name=db-master-user
spring.shardingsphere.masterslave.slave-data-source-names=db-slave-user,db-slave1-user

到此配置就完毕了。

第四步:验证

自己实现user表的增删改查。

验证的时候,通过代码增加一条数据,发现数据插入主库中。

查询数据的时候,需要自己手动往从库查几条数据做验证,发现代码查询的时候,会轮询去查两个从库。

到此验证完毕。

 

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值