首页 > 编程语言 > 详细

Spring动态数据源的配置

时间:2017-01-16 15:19:38      阅读:314      评论:0      收藏:0      [点我收藏+]

 

Spring动态数据源

 

我们很多项目中业务都需要涉及到多个数据源就是对不同的方法或者不同的包使用不同的数据源。最简单的做法就是直接在Java代码里面lookup需要的数据源但是这种做法耦合性太高,而且当逻辑流程不够严谨的时候就会出现各种大家不愿意看到的问题,因此,我们的Spring框架就给我们提供了这种强大的功能。org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource

 

基本原理如下图所示:

 技术分享

 

扩展SpringAbstractRoutingDataSource抽象类(该类充当了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()方法,来实现数据源的切换

Spring动态数据源的配置

原文:http://www.cnblogs.com/dengfukui/p/6289738.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!