java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > Spring Boot AOP事务

Spring Boot AOP与事务、异常处理交互的问题小结

作者:Qiuner

文章介绍了Spring Boot中AOP与事务、异常处理的交互,包括@Transactional注解的处理机制、事务与AOP的结合、切面执行顺序以及异常通知与事务的交互,通过示例和流程图,详细说明了在多切面环境下,通知的执行顺序及其实现原理,感兴趣的朋友跟随小编一起看看吧

Spring Boot AOP (四)与事务、异常处理交互

1. 引言

在企业项目中,AOP 不仅用于日志和性能监控,还与 事务管理异常处理 密切相关。理解 AOP、事务、异常三者的执行顺序 对架构设计和问题排查至关重要。

Spring 事务是通过 AOP 代理实现的,@Transactional 注解会生成一个事务切面,织入目标方法。

2. @Transactional 与 AOP 结合

2.1 核心机制

  1. @Transactional 注解会被 TransactionInterceptor 处理
  2. Spring 使用 环绕通知(Around Advice)在方法调用前开启事务,方法执行后提交或回滚事务
  3. 如果目标方法抛出异常,事务回滚策略生效

2.2 示例代码

@Service
public class UserService {
    @Transactional
    public void createUser(String name) {
        System.out.println("创建用户: " + name);
        if (name.equals("error")) {
            throw new RuntimeException("模拟异常");
        }
    }
}
@Aspect
@Component
public class LoggingAspect {
    @Before("execution(* com.example.service..*.*(..))")
    public void logBefore(JoinPoint jp) {
        System.out.println("日志前置: " + jp.getSignature());
    }
    @AfterReturning("execution(* com.example.service..*.*(..))")
    public void logAfter(JoinPoint jp) {
        System.out.println("日志后置: " + jp.getSignature());
    }
}

3. AOP 与事务执行顺序

切面类型执行时机
LoggingAspect@Before方法执行前
TransactionInterceptor@Around方法执行前开启事务
目标方法-执行业务逻辑
TransactionInterceptor@Around方法执行后提交或回滚事务
LoggingAspect@AfterReturning / @AfterThrowing方法返回后执行日志/异常记录

Mermaid 流程图:AOP + 事务 + 异常

flowchart TD
    A[方法调用] --> B[LoggingAspect @Before]
    B --> C[TransactionInterceptor @Around 前开启事务]
    C --> D[执行目标方法]
    D -->|正常返回| E[TransactionInterceptor 提交事务]
    D -->|异常抛出| F[TransactionInterceptor 回滚事务]
    E --> G[LoggingAspect @AfterReturning]
    F --> H[LoggingAspect @AfterThrowing]
    G --> I[返回客户端]
    H --> I

4. 异常通知与事务交互

4.1 异常通知触发条件

4.2 示例

@Aspect
@Component
public class ExceptionAspect {
    @AfterThrowing(pointcut = "execution(* com.example.service..*.*(..))", throwing = "ex")
    public void logException(JoinPoint jp, Throwable ex) {
        System.out.println("捕获异常: " + ex.getMessage() + " 方法: " + jp.getSignature());
    }
}

5. 方法调用顺序示意图

6. 多切面 + 异常 + 事务组合

@Aspect
@Component
@Order(1)
public class LoggingAspect {
    @Before("execution(* com.example.service..*.*(..))")
    public void before(JoinPoint jp) { System.out.println("日志前置"); }
}
@Aspect
@Component
@Order(2)
public class TransactionAspect {
    @Around("execution(* com.example.service..*.*(..))")
    public Object around(ProceedingJoinPoint pjp) throws Throwable {
        System.out.println("事务开始");
        try {
            Object result = pjp.proceed();
            System.out.println("事务提交");
            return result;
        } catch (Throwable ex) {
            System.out.println("事务回滚");
            throw ex;
        }
    }
}
@Aspect
@Component
@Order(3)
public class MetricsAspect {
    @AfterReturning("execution(* com.example.service..*.*(..))")
    public void afterReturning(JoinPoint jp) { System.out.println("性能监控"); }
}

执行顺序示意

flowchart TD
    A[方法调用] --> B[LoggingAspect @Before]
    B --> C[TransactionAspect @Around 前]
    C --> D[目标方法执行]
    D -->|正常| E[TransactionAspect 提交事务]
    D -->|异常| F[TransactionAspect 回滚事务]
    E --> G[MetricsAspect @AfterReturning]
    F --> H[异常处理切面执行]
    G --> I[返回客户端]
    H --> I

7. 小结

到此这篇关于Spring Boot AOP与事务、异常处理交互的问题小结的文章就介绍到这了,更多相关Spring Boot AOP事务内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文