Spring动态数据源
我们很多项目中业务都需要涉及到多个数据源,就是对不同的方法或者不同的包使用不同的数据源。最简单的做法就是直接在Java代码里面lookup需要的数据源,但是这种做法耦合性太高,而且当逻辑流程不够严谨的时候就会出现各种大家不愿意看到的问题,因此,我们的Spring框架就给我们提供了这种强大的功能。org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource
基本原理如下图所示:
扩展Spring的AbstractRoutingDataSource抽象类(该类充当了DataSource的路由中介, 能有在运行时, 根据某种key值来动态切换到真正的DataSource上。)
1.动态数据源的配置(结合公司现在的项目来讲解):
首先我们来配置数据源:项目中我配置了三个不同的数据源
1.1 db.properties文件的配置
1.2 Spring-cfg.xml中的配置:
以上的配置呢大家都会,所以我也不打算多说,所以大家根据平时的配置写就行了。
2.对数据源进行整合(需要重点注意):
这里需要重点注意一个问题:就是entry中的key需要和拦截器中常量的值对应。
Spring整合mybatis配置
配置事物管理类的调用
编写动态数据源类:继承AbstractRoutingDataSource类并且实现该类中的determineCurrentLookupKey()方法
DatabaseContextHolder这个类则是我们自己封装的对数据源进行操作的类:
DataSourceInterceptor则是我们的拦截器类:
拦截器类需要注意两个地方:
1.前面我们说过的常量的问题,我们这里常量的值必须和上面entry中的key的值一样
2.方法名的问题,在后面的切面的配置中详细跟大家说
注册拦截器
配置切入点及通知:
这里我们就来说前面说的方法名的问题:method中的值必须和拦截器中我们的方法的方法名一模一样,如果不一样会出问题(有兴趣的话大家可以去试试)
以上就是我们全部的配置过程。
、
还有一点时间呢,我带大家去看一下AbstractRoutingDataSource的源码,看一下他的实现原理。
上面这段源码的重点在于determineCurrentLookupKey()方法,这是AbstractRoutingDataSource类中的一个抽象方法,而它的返回值是你所要用的数据源dataSource的key值,有了这个key值,resolvedDataSource(这是个map,由配置文件中设置好后存入的)就从中取出对应的DataSource,如果找不到,就用配置默认的数据源。
你要扩展AbstractRoutingDataSource类,并重写其中的determineCurrentLookupKey()方法,来实现数据源的切换