Closing non transactional SqlSession 事务不生效——重复扫描

今天接手了个老项目在运行的时候发现日志中打印 

Closing non transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@376cd750]

怀疑配置有问题导致事务不生效 测试了一下果然事务没有生效 不会回滚

仔细检查了下配置文件 发现重复扫描的问题 

因为spring的context是父子容器,所以会产生冲突,由ServletContextListener产生的是父容器,springMVC产生的是子容器,子容器Controller进行扫描装配时装配了@Service注解的实例,而该实例理应由父容器进行初始化以保证事务的增强处理,所以此时得到的将是原样的Service(没有经过事务加强处理,故而没有事务处理能力。 

在springMvc的配置文件中扫描了service的所有注解

应该改为 applicationContext.xml只扫描service层和dao层,springMvc.xml只扫描controller层。

但是不清楚该项目的具体结构和内容 所以为单独解决事务不生效问题 在springMvc的配置文件中将service包中的

org.springframework.stereotype.Service注解排除掉

 

在applicationContext.xml配置文件中将

org.springframework.stereotype.Controller注解排除掉

同时service层代码声明

@Transactional(rollbackFor = Exception.class)

 

Closing non transactional SqlSession 事务不生效——重复扫描_第1张图片

 

以上三处修改完毕之后重启项目 

你可能感兴趣的:(Closing non transactional SqlSession 事务不生效——重复扫描)