国庆期间研究了数据库中间件例如Mycat和Sharding JDBC,Sharding-jdbc和Mycat使用不同的理念,Sharding-jdbc目前是基于Jdbc驱动,无需额外的proxy,因此也无需关注proxy本身的高可用。Mycat 是基于 Proxy,它复写了 MySQL 协议,将 Mycat Server 伪装成一个 MySQL 数据库,而 Sharding-JDBC 是基于 JDBC 接口的扩展,是以jar包的形式提供轻量级服务的。
先介绍一下整合过程中用到的主要软件的版本:
1 | Spring Boot: 1.5.8.RELEASE |
注意: 实现读写分离我们自己要先配置好MySQL的主从复制,我自己已经配置好了一主两从。配置的步骤可以参考【实现MySQL主从复制】
pom.xml 依赖
1 | <dependencies> |
application配置文件
1 | server.port=8080 |
sharding.jdbc.config.masterslave.load-balance-algorithm-type
查询时的负载均衡算法,目前有2种算法,round_robin(轮询)和random(随机)。算法接口是:io.shardingjdbc.core.api.algorithm.masterslave.MasterSlaveLoadBalanceAlgorithm。
实现类有RandomMasterSlaveLoadBalanceAlgorithm和RoundRobinMasterSlaveLoadBalanceAlgorithm。
sharding.jdbc.config.masterslave.master-data-source-name 主数据源名称。
sharding.jdbc.config.masterslave.slave-data-source-names 从数据源名称,多个用逗号隔开。
到此,Sharing-Jdbc的读写分离就已经就配置好了,看看是不是很简单。如果对数据的及时性要求很高,可以使用下面的代码,使得读取也落到主库上。
1 | // 强制路由主库 |