java 动态切换数据源_Java动态切换数据源(AOP)

一、对比

通过中间层来管理数据源,常用的有 mycat 等,但有一个大缺陷,就是性能的损耗,即本身直接请求数据库的事儿,却要经过中间层来进行一次分配的操作,但是,通用性比较高。

而使用客户端模式来管理数据源,直连数据库,就没有那一部分的性能损耗,但是不够通用,而且如果业务足够复杂时,对数据库的连接处理也并不 easy。

二、实现 ①自定义数据源

目录结构概览:

b12337004bd79c317bf023841ed725bd.png

采用 springboot 来实现本操作,所以下文见到的都是注解的形式。

① 配置两个数据源

db3d02ffd0bcf4c3b082e448df724df4.png

01469ce533a02db267de73f9180f16a5.png

② 使用 ThreadLocal 保存数据源,目的是保证当前数据源在当前线程中不被其它线程修改

bdb9c598a6f0503ef402d570a8b19256.png

③ 写个动态数据源的实现,需要继承 Spring 给我们提供的 AbstractRoutingDataSource 抽象类

其实就是个路由。

fc893a7a0da80b94f9d254d7f963b62c.png

④ 完成动态数据源的对象的申明 (bean)

73f35a1fa6da9b8a8fd1be4ccf20ba83.png

三、实现 ②自定义AOP

申明一个 AOP 切面,我们的做法是在 repository 层进行数据源的切换,完成后移除数据源的名称。

a44dae04b5ad9cc497f6f85af38af655.png

四、实现 ③动态切换

① 自定义注解,该注解使用目标是 dao 层方法

c14d1467199a6c2261e998763f11f639.png

② dao 层方法上加注解,没有加的就使用默认的 数据库连接

98244dca5185c08a965b104f87a9a272.png

五、测试效果

① 自定义实体类

ac3af4209a691a87ca907ea1953f1fec.png

② 写测试类,查十次,奇数次查默认数据库,否则查 test2 数据库

③ 结果,如下图,在查 test2 数据库的时候,进行了连接处的初始化动作

7e75e9d76cc7d5776f1b4370c65a76b6.png

六、总结

本文采用的是 Spring 中的 AbstractRoutingDataSource和 AOP来实现动态数据源的切换,如此简单的操作可以满足大部分基础的切换动作。

  • 1
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中,可以使用拦截器(interceptor)来实现对方法或请求的拦截,从而实现动态切换数据的功能。 在使用拦截器时,通常需要定义一个拦截器类,该类实现了Spring提供的`HandlerInterceptor`接口,并且重写了其中的方法,例如`preHandle`方法,用于在请求处理之前进行拦截。 在`preHandle`方法中,可以根据需要动态切换数据。假设系统有两个数据,分别为数据1和数据2,可以在拦截器中通过一定的规则来动态选择使用哪个数据。例如可以通过判断请求中的某些参数或者请求头来进行选择。 以下是一个简单的示例代码,用于在拦截器中根据请求参数来动态切换数据: ```java public class DataSourceInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { String dataSourceKey = request.getParameter("dataSourceKey"); if ("dataSource1".equals(dataSourceKey)) { DataSourceContextHolder.setDataSourceKey("dataSource1"); } else { DataSourceContextHolder.setDataSourceKey("dataSource2"); } return true; } } ``` 在上面的代码中,`DataSourceContextHolder`是一个自定义的类,用于保存当前线程的数据选择。在`preHandle`方法中,根据请求参数`dataSourceKey`的值来选择使用哪个数据,并将选择结果保存在`DataSourceContextHolder`中。这样,当后续的数据库操作需要使用数据时,可以从`DataSourceContextHolder`中获取当前选择的数据。 需要注意的是,拦截器只能对经过Spring MVC框架的请求进行拦截,如果直接调用Java方法,则无法进行拦截。如果需要对Java方法进行拦截,可以考虑使用AOP技术来实现。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值