0

0

Spring 中 @Transactional 的 AOP 通知实现原理详解

心靈之曲

心靈之曲

发布时间:2026-01-03 20:47:38

|

532人浏览过

|

来源于php中文网

原创

Spring 中 @Transactional 的 AOP 通知实现原理详解

spring 的 `@transactional` 并非直接对应某个单一的 `advice` 类,而是由 `transactioninterceptor`(即环绕通知)配合 `transactionattributesource` 和事务管理器协同完成,其代理创建由 `infrastructureadvisorautoproxycreator` 触发。

在 Spring AOP 体系中,@Transactional 的底层实现并非基于传统的 BeforeAdvice 或 AfterReturningAdvice,而是一个标准的 MethodInterceptor —— 即 org.springframework.transaction.interceptor.TransactionInterceptor。它本质上是一个 环绕通知(Around Advice),负责在目标方法执行前后开启、提交或回滚事务。

核心组件解析

  • TransactionInterceptor
    继承自 TransactionAspectSupport,重写了 invoke() 方法,在反射调用业务方法前获取事务属性、开启事务;方法正常返回后提交,抛出异常则按 rollbackFor/noRollbackFor 规则决定是否回滚。
    ✅ 它就是你所寻找的“实际执行事务逻辑”的 Advice。

  • TransactionAttributeSource
    负责从 @Transactional 注解中提取事务配置(如 propagation、isolation、timeout 等),默认实现为 AnnotationTransactionAttributeSource。

  • TransactionAdvisor
    将 TransactionInterceptor(advice)与 TransactionAttributeSource(pointcut 信息)封装为一个完整的 Advisor,供 AOP 框架织入。

  • 代理创建入口:InfrastructureAdvisorAutoProxyCreator
    这是 Spring 内置的 BeanPostProcessor,在 Bean 初始化后(postProcessAfterInitialization 阶段)扫描所有 Advisor(包括 TransactionAdvisor),对匹配的 Bean 创建 JDK 动态代理或 CGLIB 代理。
    ? 在 IntelliJ 中,可在此类的 wrapIfNecessary() 方法设断点,逐步跟踪代理生成及 TransactionInterceptor 的注入过程。

简单验证示例

@Service
public class OrderService {
    @Transactional
    public void createOrder() {
        System.out.println("Creating order...");
        // 数据库操作
    }
}

当该 Bean 被 Spring 容器管理时,实际注入的 OrderService 是一个代理对象。调用 createOrder() 时,真正执行的是 TransactionInterceptor.invoke(),而非原始方法。

自由画布
自由画布

百度文库和百度网盘联合开发的AI创作工具类智能体

下载

注意事项

  • ❌ 不要试图在 @Transactional 注解上 Ctrl+Click 找到 Advice —— 注解本身只是元数据,不包含逻辑;
  • ✅ 正确路径是:@EnableTransactionManagement → TransactionManagementConfigurationSelector → ProxyTransactionManagementConfiguration → TransactionInterceptor Bean 定义;
  • ⚠️ 自调用失效问题:同一类内非 public 方法或 this.method() 调用无法触发代理,因绕过了 AOP 拦截链;
  • ? 调试建议:在 TransactionInterceptor.invoke() 和 AbstractPlatformTransactionManager.getTransaction() 处设置断点,结合 Debug 模式观察事务上下文传播全过程。

掌握这一机制,不仅能理解事务如何工作,也为定制化事务行为(如扩展 TransactionAttributeSource 或替换 TransactionInterceptor)打下坚实基础。

相关专题

更多
spring框架介绍
spring框架介绍

本专题整合了spring框架相关内容,想了解更多详细内容,请阅读专题下面的文章。

101

2025.08.06

php代码编辑器入口汇总
php代码编辑器入口汇总

本文整理了主流PHP代码编辑器的官网入口及在线使用链接,阅读专题下面的文章了解更多详细内容。

2

2026.01.04

php代码编辑器地址汇总
php代码编辑器地址汇总

本文整理了主流PHP代码编辑器的官网入口及在线使用链接,阅读专题下面的文章了解更多详细内容。

0

2026.01.04

Excel制作交互图表的方法 Excel交互式的图表教程大全
Excel制作交互图表的方法 Excel交互式的图表教程大全

Excel交互式图表可通过四种方法实现:一、用切片器控制数据透视图;二、结合下拉列表与INDEX-MATCH动态引用;三、用选项按钮绑定图表系列;四、利用动态命名区域配合OFFSET函数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1

2026.01.04

php验证码教程合集
php验证码教程合集

本专题整合了php验证码php验证码教程合集,阅读专题下面的文章了解更多详细内容。

0

2026.01.04

NGINX配置指南
NGINX配置指南

本专题整合了nginx配置相关教程,阅读专题下面的文章了解更多详细内容。

0

2026.01.04

漫画合集pdf网盘入口_漫画解说合集一口气看完
漫画合集pdf网盘入口_漫画解说合集一口气看完

精选高人气漫画合集PDF,一站式网盘入口直达!深度漫画解说整合,一口气看完经典与新作,剧情梳理清晰,省时省力,追漫党必看合集。

9

2026.01.04

Java云原生微服务开发_Java如何开发云原生微服务
Java云原生微服务开发_Java如何开发云原生微服务

Java云原生微服务开发是指 利用Java语言,结合云原生理念和技术(如容器、Kubernetes),将大型应用拆解为一系列独立、小巧、松耦合的微服务,并通过轻量级API进行通信,实现快速开发、部署、弹性伸缩和高效运维的现代化应用开发模式。它融合了微服务架构(将应用拆分)与云原生技术(容器化、编排、自动化),旨在构建高可用、可扩展的分布式系统。

8

2026.01.04

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

253

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Node.js 教程
Node.js 教程

共57课时 | 7.9万人学习

Vue 教程
Vue 教程

共42课时 | 5.9万人学习

Git 教程
Git 教程

共21课时 | 2.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号