Springboot內部提供的事務(wù)管理器是根據autoconfigure來(lái)進(jìn)行決定的。
比如當使用jpa的時(shí)候,也就是pom中加入了spring-boot-starter-data-jpa這個(gè)starter之后(之前我們分析過(guò)springboot的自動(dòng)化配置原理).(更多java面試題)
Springboot會(huì )構造一個(gè)JpaTransactionManager這個(gè)事務(wù)管理器。
而當我們使用spring-boot-starter-jdbc的時(shí)候,構造的事務(wù)管理器則是DataSourceTransactionManager。
這2個(gè)事務(wù)管理器都實(shí)現了spring中提供的PlatformTransactionManager接口,這個(gè)接口是spring的事務(wù)核心接口。
這個(gè)核心接口有以下這幾個(gè)常用的實(shí)現策略:
HibernateTransactionManager
DataSourceTransactionManager
JtaTransactionManager
JpaTransactionManager
具體的PlatformTransactionManager繼承關(guān)系如下:

spring-boot-starter-data-jpa這個(gè)starter會(huì )觸發(fā)HibernateJpaAutoConfiguration這個(gè)自動(dòng)化配置類(lèi),HibernateJpaAutoConfiguration繼承了JpaBaseConfiguration基礎類(lèi)。
在JpaBaseConfiguration中構造了事務(wù)管理器:
@Bean
@ConditionalOnMissingBean(PlatformTransactionManager.class)
public PlatformTransactionManager transactionManager() {
return new JpaTransactionManager();
}
spring-boot-starter-jdbc會(huì )觸發(fā)DataSourceTransactionManagerAutoConfiguration這個(gè)自動(dòng)化配置類(lèi),也會(huì )構造事務(wù)管理器:
@Bean
@ConditionalOnMissingBean(PlatformTransactionManager.class)
@ConditionalOnBean(DataSource.class)
public DataSourceTransactionManager transactionManager() {
return new DataSourceTransactionManager(this.dataSource);
}
Spring的事務(wù)管理器PlatformTransactionManager接口中定義了3個(gè)方法:
// 基于事務(wù)的傳播特性,返回一個(gè)已經(jīng)存在的事務(wù)或者創(chuàng )建一個(gè)新的事務(wù)
TransactionStatus getTransaction(TransactionDefinition definition) throws TransactionException;
// 提交事務(wù)
void commit(TransactionStatus status) throws TransactionException;
// 回滾事務(wù)
void rollback(TransactionStatus status) throws TransactionException;
其中TransactionDefinition接口表示跟spring兼容的事務(wù)屬性,比如傳播行為、隔離級別、超時(shí)時(shí)間、是否只讀等屬性。
DefaultTransactionDefinition類(lèi)是一個(gè)默認的TransactionDefinition實(shí)現,它的傳播行為是PROPAGATION_REQUIRED(如果當前沒(méi)事務(wù),則創(chuàng )建一個(gè),否則加入到當前事務(wù)中),隔離級別是數據庫默認級別。
TransactionStatus接口表示事務(wù)的狀態(tài),比如事務(wù)是否是一個(gè)剛構造的事務(wù)、事務(wù)是否已經(jīng)完成等狀態(tài)。
下面這段代碼就是傳統事務(wù)的常見(jiàn)寫(xiě)法:
10transaction.begin();
try {
...
transaction.commit();
} catch(Exception e) {
...
transaction.rollback();
} finally {
}
由于spring的事務(wù)操作被封裝到了PlatformTransactionManager接口中,commit和rollback方法對應接口中的方法,begin方法在getTransaction方法中會(huì )被調用。
細心的讀者發(fā)現文章前面構造事務(wù)管理器的時(shí)候都會(huì )加上這段注解:
1@ConditionalOnMissingBean(PlatformTransactionManager.class)
也就是說(shuō)如果我們手動(dòng)配置了事務(wù)管理器,Springboot就不會(huì )再為我們自動(dòng)配置事務(wù)管理器。
如果要使用多個(gè)事務(wù)管理器的話(huà),那么需要手動(dòng)配置多個(gè):
@Configuration
public class DatabaseConfiguration {
@Bean
public PlatformTransactionManager transactionManager1(EntityManagerFactory entityManagerFactory) {
return new JpaTransactionManager(entityManagerFactory);
}
@Bean
public PlatformTransactionManager transactionManager2(DataSource dataSource) {
return new DataSourceTransactionManager(dataSource);
}
}
然后使用Transactional注解的時(shí)候需要聲明是哪個(gè)事務(wù)管理器:
@Transactional(value='transactionManager1')
public void save() {
doSave();
}
Spring給我們提供了一個(gè)TransactionManagementConfigurer接口,該接口只有一個(gè)方法返回PlatformTransactionManager。其中返回的PlatformTransactionManager就表示這是默認的事務(wù)處理器,這樣在Transactional注解上就不需要聲明是使用哪個(gè)事務(wù)管理器了,
聯(lián)系客服