博客
关于我
shardingsphere实现数据库读写分离
阅读量:330 次
发布时间:2019-03-04

本文共 2712 字,大约阅读时间需要 9 分钟。

实验环境:

主数据库: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,注意要引入两个包

org.apache.shardingsphere
sharding-jdbc-spring-boot-starter
4.0.0-RC3
org.apache.shardingsphere
sharding-jdbc-spring-namespace
4.0.0-RC3

第三步:配置application.properties

#读写分离配置,即一主多从方式配置debug=falseserver.port=8082server.servlet.context-path=spring.jackson.serialization.INDENT_OUTPUT=truespring.profiles.active=#spring.main.allow-bean-definition-overriding=truespring.shardingsphere.datasource.names=db-master-user,db-slave-user,db-slave1-userspring.shardingsphere.datasource.db-master-user.type=com.zaxxer.hikari.HikariDataSourcespring.shardingsphere.datasource.db-master-user.driver-class-name=com.mysql.jdbc.Driverspring.shardingsphere.datasource.db-master-user.jdbc-url=jdbc:mysql://youripaddress:3306/userdb_master?characterEncoding=utf-8&serverTimezone=UTCspring.shardingsphere.datasource.db-master-user.username=spring.shardingsphere.datasource.db-master-user.password=spring.shardingsphere.datasource.db-slave-user.type=com.zaxxer.hikari.HikariDataSourcespring.shardingsphere.datasource.db-slave-user.driver-class-name=com.mysql.jdbc.Driverspring.shardingsphere.datasource.db-slave-user.jdbc-url=jdbc:mysql://youripaddress:3306/userdb_slave0?characterEncoding=utf-8&serverTimezone=UTCspring.shardingsphere.datasource.db-slave-user.username=spring.shardingsphere.datasource.db-slave-user.password=spring.shardingsphere.datasource.db-slave1-user.type=com.zaxxer.hikari.HikariDataSourcespring.shardingsphere.datasource.db-slave1-user.driver-class-name=com.mysql.jdbc.Driverspring.shardingsphere.datasource.db-slave1-user.jdbc-url=jdbc:mysql://youripaddress:3306/userdb_slave1?characterEncoding=utf-8&serverTimezone=UTCspring.shardingsphere.datasource.db-slave1-user.username=spring.shardingsphere.datasource.db-slave1-user.password=spring.shardingsphere.masterslave.load-balance-algorithm-type=round_robinspring.shardingsphere.masterslave.name=ds_msspring.shardingsphere.masterslave.master-data-source-name=db-master-userspring.shardingsphere.masterslave.slave-data-source-names=db-slave-user,db-slave1-user

到此配置就完毕了。

第四步:验证

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

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

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

到此验证完毕。

 

转载地址:http://vcuh.baihongyu.com/

你可能感兴趣的文章
mysql 敲错命令 想取消怎么办?
查看>>
Mysql 整形列的字节与存储范围
查看>>
mysql 断电数据损坏,无法启动
查看>>
MySQL 日期时间类型的选择
查看>>
Mysql 时间操作(当天,昨天,7天,30天,半年,全年,季度)
查看>>
MySQL 是如何加锁的?
查看>>
MySQL 是怎样运行的 - InnoDB数据页结构
查看>>
mysql 更新子表_mysql 在update中实现子查询的方式
查看>>
MySQL 有什么优点?
查看>>
mysql 权限整理记录
查看>>
mysql 权限登录问题:ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)
查看>>
MYSQL 查看最大连接数和修改最大连接数
查看>>
MySQL 查看有哪些表
查看>>
mysql 查看锁_阿里/美团/字节面试官必问的Mysql锁机制,你真的明白吗
查看>>
MySql 查询以逗号分隔的字符串的方法(正则)
查看>>
MySQL 查询优化:提速查询效率的13大秘籍(避免使用SELECT 、分页查询的优化、合理使用连接、子查询的优化)(上)
查看>>
mysql 查询数据库所有表的字段信息
查看>>
【Java基础】什么是面向对象?
查看>>
mysql 查询,正数降序排序,负数升序排序
查看>>
MySQL 树形结构 根据指定节点 获取其下属的所有子节点(包含路径上的枝干节点和叶子节点)...
查看>>