博客
关于我
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 中随机抽样:order by rand limit 的替代方案
查看>>
MySQL 为什么需要两阶段提交?
查看>>
mysql 为某个字段的值加前缀、去掉前缀
查看>>
mysql 主从
查看>>
mysql 主从 lock_mysql 主从同步权限mysql 行锁的实现
查看>>
mysql 主从互备份_mysql互为主从实战设置详解及自动化备份(Centos7.2)
查看>>
mysql 主从关系切换
查看>>
MYSQL 主从同步文档的大坑
查看>>
mysql 主键重复则覆盖_数据库主键不能重复
查看>>
Mysql 事务知识点与优化建议
查看>>
Mysql 优化 or
查看>>
mysql 优化器 key_mysql – 选择*和查询优化器
查看>>
MySQL 优化:Explain 执行计划详解
查看>>
Mysql 会导致锁表的语法
查看>>
mysql 使用sql文件恢复数据库
查看>>
mysql 修改默认字符集为utf8
查看>>
Mysql 共享锁
查看>>
MySQL 内核深度优化
查看>>
mysql 内连接、自然连接、外连接的区别
查看>>