[TOC]
前段时间有项目有读写分离的需要,因此完成了该类库mybatis-read-write-split
来实现读写分离。
- 特点 支持两种模式的主备分离:
- 业务透明的读写分离。自动解析sql的读写类型并进行路由转发。
- 基于注解的读写分离。通过注解中的配置来进行读写分离。
以上两种模式可以混合使用:缺省自动解析sql的读写类型,如果注解有指定数据源,则根据注解进行路由。
- pom.xml 添加依赖
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-read-write-split-core</artifactId>
<version>2.0-SNAPSHOT</version>
</dependency>
- 配置数据源
<!--替换原本的DataSource-->
<bean id="dataSource" class="org.mybatis.rw.MultiReadDataSource">
<property name="masterDataSource" ref="masterDataSource"/>
<property name="slaveDataSourceList">
<list>
<ref bean="slaveDataSource1"></ref>
<ref bean="slaveDataSource2"></ref>
</list>
</property>
</bean>
<bean id="masterDataSource" class="com.alibaba.druid.pool.DruidDataSource" destroy-method="close">
<!--各数据源配置-->
</bean>
<bean id="slaveDataSource1" class="com.alibaba.druid.pool.DruidDataSource" destroy-method="close">
<!--各数据源配置-->
</bean>
<bean id="slaveDataSource2" class="com.alibaba.druid.pool.DruidDataSource" destroy-method="close">
<!--各数据源配置-->
</bean>
mybatis自动分析读or写操作,并进行相应的路由操作
- mybatis配置文件添加interceptor
<plugins>
<plugin interceptor="org.mybatis.rw.interceptor.ReadWriteDistinguishInterceptor">
</plugin>
</plugins>
通过方法上的注解显示指定读主库or备库
- 在目标方法上添加
@DataSource()
如
@DataSource(DataSourceType.MASTER)
public User getUserByIdFromMaster(Integer userId) {
//some operation
}
- Mapper调用MyBatis进行读写
- MyBatis分析读写类型,并存入ThreadLocal中
- 自定义DataSource从ThreadLocal里获取读写类型,路由给对应的子DataSource
- 使用对应的子DataSource进行读写操作
- Spring的切面读取注解的内容,分析 读/写 操作
- 把分析结果丢到 ThreadLocal中
- 自定义DataSource从ThreadLocal里获取DataSource类型,路由给对应的子DataSource
- 使用对应的子DataSource进行读写操作