java 两个service一个有事务一个没有_Spring事务方法嵌套引发的异常与问题分析

1 案例背景

由于Spring框架优秀的特性,很多java项目都会集成Spring。其中,Spring的轻量级声明式事务管理极大的简化了开发者对于事务的开发工作。

而我在最近的项目开发过程中,遇到了一个奇怪的事务异常:Transaction rolled back because it has been marked as rollback-only。

这篇案例将会对代码逻辑进行排查,同时对rollback-only异常进行分析。

2 案例分析

为了排查和分析rollback-only异常产生的原因,下面我会通过一个demo来模拟上述方法的调用过程。

2.1 测试用例

项目使用Springboot作为启动方式,Spring进行事务管理,Service层作为AOP事务控制的切入点。事务方法的传播属性为REQUIRED,即表示当前方法必须在一个事务中运行。如果已存在一事务正在进行,则该方法将在现有事务中运行,否则就要开始一个新事务。

为了便于理解与分析,这里简化了引发异常的业务代码,只保留关键部分。

调用过程:

f9c622b7bc5dfb857826952a262f91f8.png

事务配置类TransactionAdviceConfig.java

@Aspect
@Configuration
public class TransactionAdviceConfig {
    private static final String AOP_POINTCUT_EXPRESSION = "execution(* com.hikvision.pbg.cp.ipts.web.modules.service..*.*(..)) ";
    @Autowired
    DataSource dataSource;
​
    @Bean
    public TransactionInterceptor txAdvice() {
        DefaultTransactionAttribute txAttrRequired = new DefaultTransactionAttribute();
        txAttrRequired.setPropagationBehavior(TransactionDefinition.PROPAGATION_REQUIRED);
        NameMatchTransactionAttributeSource source = new NameMatchTransactionAttributeSource();
        source.addTransactionalMethod("save*", txAttrRequired);
        source.addTransactionalMethod("delete*", txAttrRequired);
        source.addTransactionalMethod("remove*", txAttrRequired);
        source.addTransactionalMethod("update*", txAttrRequired);
        return new TransactionInterceptor(transactionManager(), source);
    }
    @Bean
  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值