上一篇博客提到跟mybatis项目组的commiter发过邮件,后来得到了邮件回复。说是通过AbstractRoutingDataSource是可以做到的。于是我再继续的分析一下,写了一个测试,并将之前写的一些零散代码整理,重构了一下,丢到了gitHub上。地址是: https://github.com/amoszhou/spring-dynamic
关于gitHub,以前只是一直在关注,自己并没有真正使用。这次果断试了一下,确实很爽。想想以前自己写的很多东西,都是搞个U盘带着,现在云时代,gitHub的优势就体现得很明显。
具体代码就不多说了,大家可以去gitHub上拉起来看,整是项目是完整的,也有测试入口。
说说这个动态数据源吧,主要有几个注意点:
1.打包,编译必须用AspectJ。因为Spring AOP不支持拦截方法体中的方法调用(比如说A方法中调用B方法,Spring AOP只能拦截到A方法)
2.在具体的项目中,需要写一个Aspect继承至ChooseDataSourceAspect,并标记成@Aspect。因为这个项目被打成jar以后,ChooseDataSourceAspect是切不到外面的,故而将它设计成abstract的,在具体项目中继承即可,不需要写任何实现。
3.在要切换数据源的方法上 @ChooseDataSource("ds_1")即可。
4.如果开启事务的话,一定要在事务开启之前切换数据源。要规避要事务开启之后切换数据源。