springboot+mybatis实现数据库的读写分离
介绍
随着业务的发展,除了拆分业务模块外,数据库的读写分离也是常见的优化手段。
方案使用了AbstractRoutingDataSource
和mybatis plugin
来动态的选择数据源
选择这个方案的原因主要是不需要改动原有业务代码,非常友好
环境
首先,我们需要两个数据库实例,一为master,一为slave。
所有的写操作,我们在master节点上操作
所有的读操作,我们在slave节点上操作
先跑起来两个pg的实例,其中15432端口对应的master节点,15433端口对应的slave节点:
实现
整个实现主要有3个部分:
- 配置两个数据源
- 实现
AbstractRoutingDataSource
来动态的使用数据源 - 实现
mybatis plugin
来动态的选择数据源
配置数据源
将数据库连接信息配置到application.yml文件中
write写数据源,对应到master节点的15432端口
read读数据源,对应到slave节点的15433端口
将两个数据源信息注入为DataSourceProperties
:
实现AbstractRoutingDataSource
spring提供了AbstractRoutingDataSource
,提供了动态选择数据源的功能,替换原有的单一数据源后,即可实现读写分离:
AbstractRoutingDataSource
内部维护了一个Map<Object, Object>
的Map
在初始化过程中,我们将write、read两个数据源加入到这个map
调用数据源时:determineCurrentLookupKey()方法返回了需要使用的数据源对应的key
当前线程需要使用的数据源对应的key,是在DataSourceHolder
类中维护的:
实现mybatis plugin
上面提到了当前线程使用的数据源对应的key,这个key需要在mybatis plugin
根据sql类型来确定 MybatisDataSourceInterceptor
类:
仅当未在事务中,并且调用的sql是select类型时,在DataSourceHolder中将数据源设为read
其他情况下,AbstractRoutingDataSource
会使用默认的write数据源
至此,项目已经可以自动的在读、写数据源间切换,无需修改原有的业务代码
最后,提供demo使用依赖版本
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步