相关阅读
@Transactional 与@EnableTransactionManagement的使用与源码解析(一)
@Transactional 与@EnableTransactionManagement的使用及源码分析(二)
1.ProxyTransactionManagementConfiguration的解析
(1)对前面进行简单的回顾
(2)在该核心类中我们是取得事务的注解信息,并把相应的拦截器加入我们的包装类中。那我们的拦截器背后原来又是什么呢?
点击进入45行的transactionInterceptor( )
(3)我们可以看到在这里进行相应拦截器的新建与注册,但我们还是更加关注这个拦截器是怎么工作的。
所以我们继续跟进第60行的TransactionInterceptor的这个类
(4)在TransactionInterceptor这个类下我们重点关注第91行的invoke()方法,很多日常的编程经验告诉我们这个就是用来执行拦截方法的
接着我们点击进入98行的invokeWithinTransaction( )方法
(5)在该方法下:
1.先获取事务相关属性
2.获取PlatformTransactionManager事务管理器,直接到容器获取platformTransactionManager的bean实例
3.执行目标方法:
如果异常completeTransactionAfterThrowing,利用事务管理器进行回滚
如果正常: 利用事务管理器,提交事务
(6)我们对上述方法的第298行completeTransactionAfterThrowing(txInfo, ex);继续进行跟进。
在该方法下我们很明显的看到了rollbackOn( )这个关键词,这也表明我们在执行相关事务方法时,若抛出异常,就会执行回滚方法
(7)我们继续跟进在(5)中所诉第304行的方法commitTransactionAfterReturning(txInfo)
很明显该方法下有commit关键字,它表明我们在事务正确处理后就会进行提交工作。
总结:
自此,我们就通过ProxyTransactionManagementConfiguration这个类对我们注册了事务的类进行了相应的拦截,在正常执行的情况下进行像数据库一样的commit操作,如果出现错误,就会执行像数据库一样的rollbcak工作