項(xiàng)目背景:項(xiàng)目開發(fā)中數(shù)據(jù)庫使用了讀寫分離,所有查詢語句走從庫,除此之外走主庫。
最簡單的辦法其實(shí)就是建兩個(gè)包,把之前數(shù)據(jù)源那一套配置copy一份,指向另外的包,但是這樣擴(kuò)展很有限,所有采用下面的辦法。
參考了兩篇文章如下:
http://blog.csdn.net/zl3450341/article/details/20150687
http://www.blogjava.net/hoojo/archive/2013/10/22/405488.html
這兩篇文章都對原理進(jìn)行了分析,下面只寫自己的實(shí)現(xiàn)過程其他不再敘述。
實(shí)現(xiàn)思路是:
第一步,實(shí)現(xiàn)動(dòng)態(tài)切換數(shù)據(jù)源:配置兩個(gè)DataSource,配置兩個(gè)SqlSessionFactory指向兩個(gè)不同的DataSource,兩個(gè)SqlSessionFactory都用一個(gè)SqlSessionTemplate,同時(shí)重寫Mybatis提供的SqlSessionTemplate類,最后配置Mybatis自動(dòng)掃描。
第二步,利用aop切面,攔截dao層所有方法,因?yàn)閐ao層方法命名的特點(diǎn),比如所有查詢sql都是select開頭,或者get開頭等等,攔截這些方法,并把當(dāng)前數(shù)據(jù)源切換至從庫。
spring中配置如下: