spring 事务不起作用原因
spring事务不起作用
今天遇到一个问题,以前都已经配置好并且事务测试都能够回滚的事务,突然不能回滚了,遇到这问题,我就着手进行问题排查,
第一步:spring事务配置,表达式是否包含对应的方法
<!-- spring 事务 --> <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dataSource"/> </bean> <tx:advice id="txAdvice" transaction-manager="transactionManager"> <tx:attributes> <tx:method name="create*" read-only="false" propagation="REQUIRED" rollback-for="java.lang.Exception" /> <tx:method name="intser*" read-only="false" propagation="REQUIRED" rollback-for="Exception" /> <tx:method name="get*" read-only="true" propagation="REQUIRED"/> <tx:method name="update*" read-only="false" propagation="REQUIRED" rollback-for="Exception" /> <tx:method name="del*" read-only="false" propagation="REQUIRED" rollback-for="Exception" /> <tx:method name="add*" read-only="false" propagation="REQUIRED" rollback-for="Exception" /> <tx:method name="remove*" read-only="false" propagation="REQUIRED" rollback-for="Exception" /> </tx:attributes> </tx:advice> <!-- AOP 切面 --> <aop:config> <aop:pointcut id="allMethod" expression="execution(* com.xxx.service.impl.*.*(..))" /> <aop:advisor pointcut-ref="allMethod" advice-ref="txAdvice" /> </aop:config>
排查结果是没有问题
第二步:排查代码中是否使用trycatch,把异常给吃掉了
排查结果是有部分同事的代码是把异常吃掉,这种情况就需要手动抛出异常,否则spring事务管理无法截获异常,就无法进行事务回滚。所以我们必须进行手动把异常抛出去
通过在catch中thrownewRuntimeException();
第三步:排查spring配置文件和springmvc配置文件扫描类是否存在重叠,如果存在重叠也会导致事务失效的
spring-mvc.xml
<context:component-scan base-package="com.xxx.action;com.xxx.service;com.xxx.api" />
application.xml
<context:component-scan base-package="com.xxx.service" />
通过比较发现,两个配置文件的,重复扫描了com.xxx.service包,导致事务失效。
把重复扫描包去掉,事务起作用了。
相关推荐
XCMercy 2020-06-25
debugjoker 2020-04-10
snowphy 2020-05-09
予衡飞翔 2020-01-05
csuzxm000 2020-01-09
fengdos 2020-01-04
牧场SZShepherd 2020-01-03
boredbird 2020-01-03
applex 2020-01-02
vivenwan 2019-12-17
achiverhai 2019-12-07
zhaojp0 2019-11-17
happyfling 2017-07-23
大伟爱自由 2018-05-11
industry0 2019-01-23
hehezhou 2018-05-11
lhhhoo 2013-07-17
fairystepwgl 2013-10-14