理解 Spring 框架的声明式事务实现
仅仅告诉你用 @Transactional
注解来标注你的类,并在配置中添加 @EnableTransactionManagement
,然后期望你理解它所有的工作原理是不够的。为了提供更深层次的理解,本节将在与事务相关的问题背景下,解释 Spring 框架声明式事务基础设施的内部工作原理。
关于 Spring 框架的声明式事务支持,最需要掌握的概念是:这种支持是
通过 AOP 代理 实现的,并且事务通知是由元数据(目前是基于 XML 或注解的)驱动的。AOP 与事务元数据的结合产生了一个 AOP 代理,该代理使用 TransactionInterceptor
结合适当的 TransactionManager
实现来驱动方法调用周围的事务。
Spring AOP 涵盖在 AOP 部分。 |
Spring 框架的 TransactionInterceptor
为命令式和响应式编程模型提供事务管理。拦截器通过检查方法返回类型来检测所需的事务管理风格。返回响应式类型(如 Publisher
或 Kotlin Flow
(或其子类型))的方法符合响应式事务管理。所有其他返回类型,包括 void
,都使用命令式事务管理的代码路径。
事务管理风格会影响所需的事务管理器。命令式事务需要 PlatformTransactionManager
,而响应式事务使用 ReactiveTransactionManager
实现。
|
下图显示了调用事务代理上的方法的概念视图:
