热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Spring4.2.5中Bean在ContextRefreshedEvent上未启用事务代理的问题

本文探讨了一个特定于Spring4.2.5的问题,即在应用上下文刷新事件(ContextRefreshedEvent)触发时,带有@Transactional注解的Bean未能正确代理事务。该问题在Spring4.1.9版本中正常运行,但在升级至4.2.5后出现异常。

在 Spring 4.2.5 中遇到一个问题,当应用上下文刷新事件(ContextRefreshedEvent)被触发时,带有 @Transactional 注解的 Bean 未能正确代理事务。具体来说,SettingService Bean 虽然标注了事务注解,但其在事件处理过程中并未如预期那样作为 JDK 动态代理实例存在。

以下是相关代码示例:

public class DefaultConfigManager implements ApplicationListener, ConfigManager {
@Autowired
private SettingService service;
@Override
public void onApplicationEvent(ContextRefreshedEvent event) {
System.out.println("Proxy: " + AopUtils.isJdkDynamicProxy(service));
String key = service.getSystemSetting("KEY");
}
}

在 Spring 4.1.9 版本中,上述代码能够正常运行,控制台输出显示 SettingService Bean 是一个动态代理对象,表明事务管理功能正常运作。然而,在升级到 Spring 4.2.5 后,相同的代码开始抛出异常:

org.hibernate.HibernateException: Could not obtain transaction-synchronized Session for current thread

at org.springframework.orm.hibernate4.SpringSessionContext.currentSession(SpringSessionContext.java:134)

at org.hibernate.internal.SessionFactoryImpl.getCurrentSession(SessionFactoryImpl.java:993)

进一步检查发现,此时 SettingService Bean 已不再是一个代理对象,这意味着事务管理功能失效。

尽管按照 Spring 文档说明,所有 Bean 和后处理器应在发布 ContextRefreshedEvent 之前完成初始化,但实际情况似乎并非如此。已确认应用程序上下文中配置了 Hibernate 事务管理器,且 tx:annotation-driven 元素已设置,@Transactional 注解应用于实现类而非接口,同时系统中不存在循环依赖。使用的 Hibernate 版本为 4.2.20.Final。

此问题可能与 Spring 4.1 和 4.2 版本之间的一些已知差异有关。例如,Spring 4.2 引入了一些针对 AOP 代理机制的改进,这些改进可能导致了旧有代码行为的变化。此外,Spring 4.2 对事务管理器的配置方式进行了调整,可能影响了事务代理的创建过程。

解决这一问题的一种方法是在类级别而非方法级别添加 @Transactional 注解。通过这种方式,可以确保整个类的所有公共方法都处于事务管理之下,从而避免因特定方法调用而引发的事务管理问题。


推荐阅读
  • Spring Boot 入门指南
    本文介绍了Spring Boot的基本概念及其在现代Java应用程序开发中的作用。Spring Boot旨在简化Spring应用的初始设置和开发过程,通过自动配置和约定优于配置的原则,帮助开发者快速构建基于Spring框架的应用。 ... [详细]
  • Java 架构:深入理解 JDK 动态代理机制
    代理模式是 Java 中常用的设计模式之一,其核心在于代理类与委托类共享相同的接口。代理类主要用于为委托类提供预处理、过滤、转发及后处理等功能,以增强或改变原有功能的行为。 ... [详细]
  • 本文将探讨从ASP.NET 1.1到2.0期间编译系统的重要变革。通过对比两个版本的即时编译模型,我们将揭示2.0版本中引入的新特性和改进之处。 ... [详细]
  • 本文详细介绍了ASP.NET缓存的基本概念和使用方法,包括输出缓存、数据缓存及其高级特性,如缓存依赖、自定义缓存和缓存配置文件等。通过合理利用这些缓存技术,可以显著提升Web应用程序的性能。 ... [详细]
  • 本文探讨如何利用Java反射技术来模拟Webwork框架中的URL解析过程。通过这一实践,读者可以更好地理解Webwork及其后续版本Struts2的工作原理,尤其是它们在MVC架构下的角色。 ... [详细]
  • 本文详细介绍了 Kubernetes 集群管理工具 kubectl 的基本使用方法,涵盖了一系列常用的命令及其应用场景,旨在帮助初学者快速掌握 kubectl 的基本操作。 ... [详细]
  • 最近同事提了一个需求过来,他觉得项目对于第三方日志记录的太多了,只想记录一些业务相关的日志减少对于框架日志的显示。具体要求就是对于框架日志只显示warn等级以上的,而业务日志显示info等级以上 ... [详细]
  • 在Linux系统上构建Web服务器的详细步骤
    本文详细介绍了如何在Linux系统上搭建Web服务器的过程,包括安装Apache、PHP和MySQL等关键组件,以及遇到的一些常见问题及其解决方案。 ... [详细]
  • 本文探讨了浏览器的同源策略限制及其对 AJAX 请求的影响,并详细介绍了如何在 Spring Boot 应用中优雅地处理跨域请求,特别是当请求包含自定义 Headers 时的解决方案。 ... [详细]
  • 详细指南:使用IntelliJ IDEA构建多模块Maven项目
    本文在前两篇文章的基础上,进一步指导读者如何在IntelliJ IDEA中创建和配置多模块Maven项目。通过详细的步骤说明,帮助读者掌握项目模块化管理的方法。 ... [详细]
  • 本文将指导如何在JFinal框架中快速搭建一个简易的登录系统,包括环境配置、数据库设计、项目结构规划及核心代码实现等环节。 ... [详细]
  • MapReduce原理是怎么剖析的
    这期内容当中小编将会给大家带来有关MapReduce原理是怎么剖析的,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。1 ... [详细]
  • Flowable系列教程:运用ProcessEngineConfigurator实现高级流程引擎配置
    本文探讨了通过ProcessEngineConfigurator接口实现对Flowable流程引擎的高级配置方法。这种方法允许开发者通过自定义配置器来增强或修改流程引擎的行为。 ... [详细]
  • 利用RabbitMQ实现高效延迟任务处理
    本文详细探讨了如何利用RabbitMQ实现延迟任务,包括其应用场景、实现原理、系统设计以及具体的Spring Boot实现方式。 ... [详细]
  • 本文探讨了使用Filter作为控制器的优势,以及Servlet与Filter之间的主要差异。同时,详细解析了Servlet的工作流程及其生命周期,以及ServletConfig与ServletContext的区别与应用场景。 ... [详细]
author-avatar
kaiping2011
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有