无法获取当前线程的事务同步会话
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 中,我为DataSource
、SessionFactory
、HibernateTransactionManager
、ImprovedNamingStrategy
配置了@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 - 无法为当前线程获取事务同步会话
错误:无法使用 spring 任务执行器获取当前线程的事务同步会话