javascript
使用Spring @Transactional进行数据源路由
卡爾·帕帕(Carl Papa)在Spring框架中使用方面來確定要使用的DataSource (讀寫或只讀)啟發了我。 所以,我正在寫這篇文章。
我必須承認,我對Spring的AbstractRoutingDataSource早已熟悉。 但是我不知道在哪里可以使用它。 感謝卡爾和團隊,以及他們的項目之一。 現在,我知道了一個很好的用例。
@交易
在Spring中,只讀事務通常帶有注釋。
public class ... {@Transactional(readOnly=true)public void ...() {...}@Transactional // read-writepublic void ...() {...} }為了利用這一點,我們使用Spring的TransactionSynchronizationManager來確定當前事務是否為只讀。
AbstractRoutingDataSource
在這里,如果當前事務是只讀的,我們使用Spring的AbstractRoutingDataSource路由到只讀副本。 否則,它將路由到默認主機。
public class ... extends AbstractRoutingDataSource {@Overrideprotected Object determineCurrentLookupKey() {if (TransactionSynchronizationManager.isCurrentTransactionReadOnly() ...) {// return key to a replica}return null; // use default}... }使用上述方法后,我們發現TransactionSynchronizationManager落后了一步,因為Spring 在建立同步之前已經調用了DataSource.getConnection() 。 因此, LazyConnectionDataSourceProxy需要配置LazyConnectionDataSourceProxy 。
在討論這個問題時,我們發現是否存在另一種方法來確定當前事務是否為只讀(無需使用LazyConnectionDataSourceProxy )。 因此,我們提出了一種實驗方法,其中一個方面將TransactionDefinition (來自@Transactional批注,如果有的話)捕獲為線程局部變量,以及一個AbstractRoutingDataSource根據捕獲的信息進行路由。
相關源代碼可以在GitHub上找到 。 再次感謝, 卡爾 ! 順便說一句, 卡爾也是獲獎電影導演。 哇,才華橫溢。
翻譯自: https://www.javacodegeeks.com/2018/01/datasource-routing-spring-transactional.html
總結
以上是生活随笔為你收集整理的使用Spring @Transactional进行数据源路由的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: jpa 异常捕获_JPA和CMT –为什
- 下一篇: nba2k16怎么玩电脑版(nba2k1