前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >springboot+mybatis-plus实现读写分离

springboot+mybatis-plus实现读写分离

原创
作者头像
shigen
发布2023-10-28 18:39:13
3960
发布2023-10-28 18:39:13
举报

shigen坚持日更的博客写手,擅长Java、python、vue、shell等编程语言和各种应用程序、脚本的开发。坚持记录和分享从业两年以来的技术积累和思考,不断沉淀和成长。

最近shigen加班也比较严重,很多天文章没有更新了,各位读者和伙伴见谅哈。

好的,现在我们进入正题。在之前的文章一文讲清楚mysql主从服务的搭建过程中,我相信伙伴们已经清楚了docker如何快速的搭建mysql主从服务了。那怎么使用呢?这个问题在shigen的心里藏了很久,趁着周末的功夫我正好研究了一下,并把我的代码master-slave-demo放在了gitee上,感兴趣的伙伴可以自己上去看看。当然,也欢迎大家提出优化的点,shigen会及时的回复和更新。

在开始之前,我们用一个图展示出读写分离的原理:

读写分离的原理
读写分离的原理

不会这么简单吧,是的你没有看错。就当我思考如何展示出这个概念的时候,我发现一张图就这样简单的展示出来了,不可思议。但是事实就是这么简单。

现在,我们的难点就是如何判断用户的请求是读请求还是写请求,然后切换到不同的数据库。 若依框架的多数据库似乎给了我灵感,但是我还没来得及看。现在自己造一个出来,文章中的部分代码参考springboot+mybatis-plus实现读写分离

老规矩,我们先把自己的mysql集群启动。

启动mysql集群
启动mysql集群

启动完毕之后,我们开始新建项目:master-slave-demo

引入项目需要的依赖

常用的我不说了,这里需要注意:

  • 引入spring-boot-starter-aop,我们需要用到spring的切片功能
  • mysql的驱动名字变了!com.mysql.mysql-connector-j,伙伴们可以关注一下
  • 需要进入alibaba的druid实现多数据源

配置文件多数据源

这里主要是配置了多个数据源,还有mybatis-plus需要的配置,具体的配置项含义可参考详细的注释

配置类

这里主要是读取我们在yaml配置文件的配置,并将bean放在DateSource中,现在我们需要的是一个路由,动态的切换数据源

数据源路由

数据源路由应需求而生,我们需要做的事就是从重写一下路由规则,规则是我们定制的,这里我们设置了一个dataSourceContextHolder。这个是不是很熟悉,什么holder的 ,就自然引入了线程上下文ThreadLocal

DataSourceContextHolder

这里的轮训是我设计的一个缺陷,我之前针对的是一主两从的设计,所以对2取模,这里对于一主一丛,设计的作用不大。这个类主要的作用就是将不同的数据源塞到县城上下文中。那我们怎么决定呢?我们需要一个切片!

切片设计

代码的核心,主要是拦截我们去查询、修改数据的方法,然后修改上下文。其中,Master注解是我单独设计的,可以用来实现这样的功能:部分接口查询主数据库。其它的就是spring的aop的使用了,这里不加赘述!

补充

需要注意的是,我们的ORM框架是mybatis-plus,我们仍然需要告诉它:你该用哪个数据源。

OK,一番准备之后,我们来测试一下实现的效果。效果我们可以看到会打印出部分的日志,我们根据日志区分,同时我也会采用断点跟进的方式,动态追踪代码。

对,我先看一下我的测试接口:

开始测试了!

  • 查询数据
查询数据测试
查询数据测试
  • 查询数据,但是从主节点
从主节点查询数据
从主节点查询数据

这里有个很有意思的现象,出现了进入读切点的日志,@Master应该放在service包下的方法。

对,这里需要改一下:

因为现在只有一个从节点了,不需要轮训了。

  • 添加数据
添加数据测试
添加数据测试

可以看到效果已经实现了,源码可以到上文提到的仓库查看。


以上就是今天分享的全部内容了,觉得不错的话,记得点赞 在看 关注支持一下哈,您的鼓励和支持将是shigen坚持日更的动力。同时,shigen在多个平台都有文章的同步,也可以同步的浏览和订阅:

平台

备注

链接

CSDN

知名博客平台,很少关注

知乎

专注内容分享和问题解答

掘金

高质量博客平台

腾讯云开发者社区

腾讯云开发者社区

微信公众平台

个人微信公众号,分享技术和日常

公众号名:shigen

shigen一起,每天不一样!

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 引入项目需要的依赖
  • 配置文件多数据源
  • 配置类
  • 数据源路由
  • DataSourceContextHolder
  • 切片设计
  • 补充
相关产品与服务
云数据库 MySQL
腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档