目录
怎么保证Service用到的DataSource跟Doa用到的一致
事务模板执行对象接口:TransactionCallback
事务管理器:DataSourceTransactionManager
事务初始化信息:DefaultTransactionDefinition
事务管理器父类AbstractPlatformTransactionManager
事务同步管理TransactionSynchronizationManager
怎么读
这个只是点到每个节点上,需要参考源码来读。只看这个估计看不懂。
Spring事务的实现源码
要想把事务提到Service层,如果是AOP注入事务方式,则其实是提到了Service以上。那么,就需要在这是之前就获取数据库连接Connect,只有这个对象可以操作事务。
DataSource是许多Connect的封装集合,获取数据库连接的对象。那么DataSource怎么就认为一个Connect没用了?
Spring通过DataSourceTransactionManager是对事务的管理和所有操作,理所应当应该有DataSource。DefaultTransactionDefinition是开启事务的参数,其中两个重要的参数是:事务的隔离性,事务的传播性。通过DataSourceTransactionManager. getTransaction(DefaultTransactionDefinition)来获取事务,返回的是TransactionStatus标识新事务状态,你并不能拿到事务对象,事务管理器负责获取,提交,回滚事务。
示例代码:
DefaultTransactionDefinition definition = new DefaultTransactionDefinition();
//设置事务的隔离性,默认数据库的事务隔离性
definition.setIsolationLevel(TransactionDefinition.ISOLATION_READ_COMMITTED);
//设置事务的传播性,默认使用当前,如果没有则创建
definition.setPropagationBehavior(TransactionDefinition.PROPAGATION_SUPPORTS);
//开启事务
TransactionStatus tx1 = txm1.getTransaction(definition );
try {
Loginusers arg0 = new Loginusers();
this.loginusersUDMapper.insert(arg0 );
this.loginusersUDMapper.insert(arg0 );
throw new Exception("123");
} catch (Exception e) {
//回滚
txm1.rollback(tx1);
}
//提交
txm1.commit(tx1);
Spring实现事务的方式
编程式事务
直接使用TransactionManager或者用TransactionTemplate编程。
声明式事务
使用AOP实现或者注解都可以。
怎么保证Service用到的DataSource跟Doa用到的一致
Service层使用的Connect使用后放在ThreadLocal中TransactionSynchronizationManager属性。在Doa使用的时候当然就可以直接get到啦。
当然这里必须考虑事务的传播特性。
源码解析
事务模板:TransactionTemplate
- 封装了DataSourceTransactionManager
- <T> T execute(TransactionCallback<T> action) 方法执行实现了TransactionCallback接口的类,返回T对象。
事务模板执行对象接口:TransactionCallback
只有一个方法:T doInTransaction(TransactionStatus status); 就是你需要事务包裹的逻辑。
事务管理器:DataSourceTransactionManager
getTransaction获取事务,返回事务状态TransactionStatus
commit提交事务
rollback 回滚事务
继承了:AbstractPlatformTransactionManager
方法:void doBegin(Object transaction, TransactionDefinition definition);新建一个事务。
事务初始化信息:DefaultTransactionDefinition
//设置事务的隔离性
setIsolationLevel(TransactionDefinition.ISOLATION_READ_COMMITTED);
//设置事务的传播性
setPropagationBehavior(TransactionDefinition.PROPAGATION_REQUIRED);
事务管理器父类AbstractPlatformTransactionManager
获取事务方法
TransactionStatus getTransaction(TransactionDefinition definition)
他会根据不同传播特性判断是否需要新建事务。
开启新事务(调用的是子类DataSourceTransactionManager.doBegin方法)
看到了吧,获取连接了。
控制事务同步管理,记录一些事务特性
void prepareSynchronization(DefaultTransactionStatus status, TransactionDefinition definition)
使用的是TransactionSynchronizationManager类的静态方法操作。
事务同步管理TransactionSynchronizationManager
使用的ThreadLocal类,根据线程来控制的,以后该线程再次获取的时候就直接get方法就可以获取到。
END