无法获取当前线程的事务同步会话

Posted

技术标签:

【中文标题】无法获取当前线程的事务同步会话【英文标题】:Could not obtain transaction-synchronized Session for current thread 【发布时间】:2014-11-28 12:35:19 【问题描述】:

我从 xml- 转换为 Java-Config 的 Spring4/Hibernate4 项目出现以下异常。

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

项目在 Eclipse 中启动属性并且没有错误,但在第一次请求时出现异常。在我的ConfigRoot-class 中,我为DataSourceSessionFactoryHibernateTransactionManagerImprovedNamingStrategy 配置了@Bean

我所有的@Service 服务都带有@Transactional 注释。

知道这可能来自哪里吗?

编辑 1

根据要求,这里是堆栈跟踪:

org.springframework.web.util.NestedServletException:请求处理失败;嵌套异常是 org.hibernate.HibernateException: org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:978) org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:857) javax.servlet.http.HttpServlet.service(HttpServlet.java:621) org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:842) javax.servlet.http.HttpServlet.service(HttpServlet.java:722) org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:88) org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107) org.springframework.web.filter.HiddenHttpMethodFilter.doFilterInternal(HiddenHttpMethodFilter.java:77) org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107) org.hibernate.HibernateException: org.springframework.orm.hibernate4.SpringSessionContext.currentSession(SpringSessionContext.java:134) org.hibernate.internal.SessionFactoryImpl.getCurrentSession(SessionFactoryImpl.java:1014) employees.service.PersonService.getAllInHierarchcalOrder(PersonService.java:58) employees.controller.PersonController.getPersons(PersonController.java:64) sun.reflect.NativeMethodAccessorImpl.invoke0(本机方法) sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) java.lang.reflect.Method.invoke(Method.java:606) org.springframework.web.method.support.InvocableHandlerMethod.invoke(InvocableHandlerMethod.java:215) org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:132) org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:104) org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandleMethod(RequestMappingHandlerAdapter.java:781) org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:721) org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:83) org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:943) org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:877) org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:966) org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:857) javax.servlet.http.HttpServlet.service(HttpServlet.java:621) org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:842) javax.servlet.http.HttpServlet.service(HttpServlet.java:722) org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:88) org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107) org.springframework.web.filter.HiddenHttpMethodFilter.doFilterInternal(HiddenHttpMethodFilter.java:77) org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)

编辑 2

奇怪的是,我从另一个完美运行的项目中借用了整个 Java-Config 代码,当然我错过了一个细节。这就是为什么我不考虑Some transaction propagations not working with Spring/Hibernate 4。

【问题讨论】:

查看SO question。 如果至少你显示了堆栈跟踪...... 【参考方案1】:

刚刚找到它...我的根配置类中缺少@EnableTransactionManagement

感谢大家的指导。

【讨论】:

直到现在我还没有使用过@EnableTransactionManagement。到目前为止,我所有的服务层和 dao 层都运行良好。突然发现这个问题。而且,同一道有一种保存方法,而且效果很好。只有当我尝试创建标准时,它才会出现问题。其他 dao 仍然可以正常工作。你有什么建议吗?【参考方案2】:

我认为这是未使用事务代理的问题(只是堆栈跟踪的猜测)。默认情况下,spring 为其使用 Jdk 代理,但这需要将服务导入控制器中作为接口

如果是这种情况,请创建一个接口IPersonService,其中包含来自PersonService 的相关方法,并将其导入PersonController@Autowired IPersonService personService; 甚至更好,将PersonService 重命名为PersonServiceImpl 并制作PersonService一个接口。

而且...始终如一地为您的所有交易服务做到这一点...

【讨论】:

【参考方案3】:

这样的场景:

使用此拇指规则

1) 对于每个@Entity @Table(name = "Table1")

创建对应的Services,以及对应的DAO。

【讨论】:

以上是关于无法获取当前线程的事务同步会话的主要内容,如果未能解决你的问题,请参考以下文章

Spring Hibernate - 无法为当前线程获取事务同步会话

Hibernate 4无法为当前线程获取事务同步会话

错误:无法使用 spring 任务执行器获取当前线程的事务同步会话

无法使用“getcurrentsession”获取当前线程的事务同步会话,但使用“opensession”工作正常吗?

如何快速杀掉堵塞MySQL的会话

Java AQS源码阅读