2014-02-26 13 views
1

我正在使用SpringHibernate。我正在使用JBoss EAP 6.1作爲我的應用服務器。在我的應用程序中,在Spring + hibernate中獲取「Closed connection」問題

我用通過下面的代碼創建sessionFactory休眠

<bean id="sessionFactory" 
     class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean"> 
     <property name="dataSource" ref="dataSource" /> 
     <property name="annotatedClasses"> 
      <list> 
        <!-- list of annotatedClasses --> 
      </list> 
     </property> 
     <property name="hibernateProperties"> 
      <props> 
       <prop key="hibernate.jdbc.batch_size">100</prop> 
       <prop key="hibernate.current_session_context_class">thread</prop> 
       <prop key="hibernate.dialect">${hibernate.dialect}</prop> 
       <prop key="hibernate.show_sql">${hibernate.show_sql}</prop> 
       <prop key="hibernate.hbm2ddl.auto">$(hibernate.hbm2ddl.auto)</prop> 
       <prop key="hibernate.query.factory_class">org.hibernate.hql.classic.ClassicQueryTranslatorFactory 
       </prop> 
       <prop key="hibernate.connection.autocommit">false</prop> 
      </props> 
     </property> 
</bean> 

自動裝配AutowiredsessionFactory春DAO類爲:

@Autowired 
private SessionFactory sessionFactory; 

我有使用sessionFactory作爲如下得到休眠Session

Session session = sessionFactory.getCurrentSession(); 
try { 
    session.beginTransaction(); 
    Query sqlQuery = session.createSQLQuery(query).addEntity(className); 

    if (null != arg) 
     sqlQuery.setParameters(arg, type); 

    list = sqlQuery.list(); 
    session.getTransaction().commit(); 
} catch (HibernateException ex) { 
    LOG.error(ex); 
    session.getTransaction().rollback(); 
    throw ex; 
} 
sessionFactory.getCurrentSession().close(); 

如上面的代碼所示,我已經關閉了,每次休眠Session。不過我正在關閉連接的問題,我跑我的申請後約半小時:

17:25:15,500 ERROR [org.hibernate.transaction.JDBCTransaction] (http--0.0.0.0-8080-5) JDBC rollback failed: java.sql.SQLRecoverableException: Closed Connection 
    at oracle.jdbc.driver.PhysicalConnection.rollback(PhysicalConnection.java:3901) [ojdbc6.jar:11.2.0.2.0] 
    at org.jboss.jca.adapters.jdbc.BaseWrapperManagedConnection.jdbcRollback(BaseWrapperManagedConnection.java:1010) 
    at org.jboss.jca.adapters.jdbc.WrappedConnection.rollback(WrappedConnection.java:778) 
    at org.hibernate.transaction.JDBCTransaction.rollbackAndResetAutoCommit(JDBCTransaction.java:217) [hibernate-core.jar:3.3.0.SP1] 
    at org.hibernate.transaction.JDBCTransaction.rollback(JDBCTransaction.java:196) [hibernate-core.jar:3.3.0.SP1] 
    at com.ghcm.emailselection.db.DBOperations.selectRecordForBean(DBOperations.java:91) [classes:] 
    at com.ghcm.emailselection.dao.UserSpecificDetailsDaoImpl.getUserInfo(UserSpecificDetailsDaoImpl.java:34) [classes:] 
    at com.ghcm.emailselection.service.UserSpecificDetailsImpl.getUserInfo(UserSpecificDetailsImpl.java:32) [classes:] 
    at com.ghcm.emailselection.dao.LoginDAOImpl.doLogin(LoginDAOImpl.java:97) [classes:] 
    at com.ghcm.emailselection.service.LoginServiceImpl.doLogin(LoginServiceImpl.java:80) [classes:] 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) [rt.jar:1.6.0_22] 
    at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) [rt.jar:1.6.0_22] 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) [rt.jar:1.6.0_22] 
    at java.lang.reflect.Method.invoke(Unknown Source) [rt.jar:1.6.0_22] 
    at org.springframework.aop.support.AopUtils.invokeJoinpointUsingReflection(AopUtils.java:319) [spring-aop-3.1.3.RELEASE.jar:3.1.3.RELEASE] 
    at org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:196) [spring-aop-3.1.3.RELEASE.jar:3.1.3.RELEASE] 
    at $Proxy195.doLogin(Unknown Source) at com.ghcm.emailselection.controller.LoginController.dologin(LoginController.java:69) [classes:] 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) [rt.jar:1.6.0_22] 
    at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) [rt.jar:1.6.0_22] 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) [rt.jar:1.6.0_22] 
    at java.lang.reflect.Method.invoke(Unknown Source) [rt.jar:1.6.0_22] 
    at org.springframework.web.method.support.InvocableHandlerMethod.invoke(InvocableHandlerMethod.java:219) [spring-web-3.1.3.RELEASE.jar:3.1.3.RELEASE] 
    at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:132) [spring-web-3.1.3.RELEASE.jar:3.1.3.RELEASE] 
    at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:100) [spring-webmvc-3.1.3.RELEASE.jar:3.1.3.RELEASE] 
    at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:604) [spring-webmvc-3.1.3.RELEASE.jar:3.1.3.RELEASE] 
    at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:565) [spring-webmvc-3.1.3.RELEASE.jar:3.1.3.RELEASE] 
    at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:80) [spring-webmvc-3.1.3.RELEASE.jar:3.1.3.RELEASE] 
    at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:923) [spring-webmvc-3.1.3.RELEASE.jar:3.1.3.RELEASE] 
    at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:852) [spring-webmvc-3.1.3.RELEASE.jar:3.1.3.RELEASE] 
    at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:882) [spring-webmvc-3.1.3.RELEASE.jar:3.1.3.RELEASE] 
    at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:789) [spring-webmvc-3.1.3.RELEASE.jar:3.1.3.RELEASE] 
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:754) [jboss-servlet-api_3.0_spec-1.0.0.Final.jar:1.0.0.Final] 
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:847) [jboss-servlet-api_3.0_spec-1.0.0.Final.jar:1.0.0.Final] 
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:329) [jbossweb-7.0.10.Final.jar:] 
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:248) [jbossweb-7.0.10.Final.jar:] 
    at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330) [spring-security-web-3.1.3.RELEASE.jar:3.1.3.RELEASE] 
    at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:118) [spring-security-web-3.1.3.RELEASE.jar:3.1.3.RELEASE] 
    at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:84) [spring-security-web-3.1.3.RELEASE.jar:3.1.3.RELEASE] 
    at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:342) [spring-security-web-3.1.3.RELEASE.jar:3.1.3.RELEASE] 
    at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:113) [spring-security-web-3.1.3.RELEASE.jar:3.1.3.RELEASE] 
    at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:342) [spring-security-web-3.1.3.RELEASE.jar:3.1.3.RELEASE] 
    at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:103) [spring-security-web-3.1.3.RELEASE.jar:3.1.3.RELEASE] 
    at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:342) [spring-security-web-3.1.3.RELEASE.jar:3.1.3.RELEASE] 
    at org.springframework.security.web.authentication.AnonymousAuthenticationFilter.doFilter(AnonymousAuthenticationFilter.java:113) [spring-security-web-3.1.3.RELEASE.jar:3.1.3.RELEASE] 
    at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:342) [spring-security-web-3.1.3.RELEASE.jar:3.1.3.RELEASE] 
    at org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:54) [spring-security-web-3.1.3.RELEASE.jar:3.1.3.RELEASE] 
    at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:342) [spring-security-web-3.1.3.RELEASE.jar:3.1.3.RELEASE] 
    at org.springframework.security.web.savedrequest.RequestCacheAwareFilter.doFilter(RequestCacheAwareFilter.java:45) [spring-security-web-3.1.3.RELEASE.jar:3.1.3.RELEASE] 
    at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:342) [spring-security-web-3.1.3.RELEASE.jar:3.1.3.RELEASE] 
    at com.ghcm.emailselection.controller.CustomAuthenticationFilter.doFilter(CustomAuthenticationFilter.java:77) [classes:] 
    at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:342) [spring-security-web-3.1.3.RELEASE.jar:3.1.3.RELEASE] 
    at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:87) [spring-security-web-3.1.3.RELEASE.jar:3.1.3.RELEASE] 
    at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:342) [spring-security-web-3.1.3.RELEASE.jar:3.1.3.RELEASE] 
    at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:192) [spring-security-web-3.1.3.RELEASE.jar:3.1.3.RELEASE] 
    at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:160) [spring-security-web-3.1.3.RELEASE.jar:3.1.3.RELEASE] 
    at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:346) [spring-web-3.1.3.RELEASE.jar:3.1.3.RELEASE] 
    at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:259) [spring-web-3.1.3.RELEASE.jar:3.1.3.RELEASE] 
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:280) [jbossweb-7.0.10.Final.jar:] 
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:248) [jbossweb-7.0.10.Final.jar:] 
    at com.utxfrmwk.security.filter.SecurityInterceptor.doFilter(SecurityInterceptor.java:40) [UtxSecurityUtility.jar:] 
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:280) [jbossweb-7.0.10.Final.jar:] 
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:248) [jbossweb-7.0.10.Final.jar:] 
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:275) [jbossweb-7.0.10.Final.jar:] 
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:161) [jbossweb-7.0.10.Final.jar:] 
    at org.jboss.as.web.security.SecurityContextAssociationValve.invoke(SecurityContextAssociationValve.java:154) [jboss-as-web-7.1.0.Final.jar:7.1.0.Final] 
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:155) [jbossweb-7.0.10.Final.jar:] 
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102) [jbossweb-7.0.10.Final.jar:] 
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109) [jbossweb-7.0.10.Final.jar:] 
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:368) [jbossweb-7.0.10.Final.jar:] 
    at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:877) [jbossweb-7.0.10.Final.jar:] 
    at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:671) [jbossweb-7.0.10.Final.jar:] 
    at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:930) [jbossweb-7.0.10.Final.jar:] 
    at java.lang.Thread.run(Unknown Source) [rt.jar:1.6.0_22] 

我大約每半小時一班經常面臨這樣的問題。我需要挖掘JNDI池或重新啓動JBOSS應用服務器來解決它。

任何人都可以告訴我我做錯了什麼,或者我應該採取什麼行動來解決「封閉的連接」問題?

請幫忙!

+0

嘗試session.close(。的getCurrentSession()。close()方法。沒有任何意義 –

+0

sessionFactory.getCurrentSession()。close()不是必需的,因爲您使用的是hibernate.current_session_context_class = thread,當事務提交或回滾時會話將自動關閉。請嘗試刪除那個 – Atul

+0

@Atul最初我沒有使用close()方法,並得到相同的問題。這就是爲什麼我在事務結束後添加close()方法的原因。 – gohil90

回答

0

我建議一些方法來使用會話:使用

的openSession()

的openSession()打開一個新的會話,你必須關閉一旦你完成。

Session session = sessionFactory.openSession(); 

Transaction tx = null; 
try { 

    //get a transaction before performing any operations.. 
    tx = session.beginTransaction(); 

    //perform your transaction here 

    //commit the transaction as it is success. 
    tx.commit(); 
} catch (HibernateException ex) { 
    //rollback the current transaction, since a exception occurred, while performing transaction 
    if(tx!=null) 
     tx.rollback(); 
    throw ex; 
}finally{ 

    //finally close the session, since transaction is completed. 
    session.close(); 
} 

使用的getCurrentSession():

,正如你在Hibernate配置屬性都設置hibernate.current_session_context_classthread這意味着Hibernate會autometically關閉會話當交易完成。

//getCurrentSession() returns a session bound to a context, you don't need to close this 
    Session session = sessionFactory.getCurrentSession(); 

    Transaction tx = null; 
    try { 

     //get a transaction before performing any operations.. 
     tx = session.beginTransaction(); 

     //perform your transaction here 

     //commit the transaction as it is success. 
     tx.commit(); 
    } catch (HibernateException ex) { 
     //rollback the current transaction, since a exception occurred, while performing transaction 
     if(tx!=null) 
      tx.rollback(); 
     throw ex; 
    } 
1

爲每ThreadLocalSessionContextthis文檔,您已通過<prop key="hibernate.current_session_context_class">thread</prop>

配置在可用性的利益,因此決定這個默認IMPL實際上產生在第一次請求,然後乾淨會話在與該會話相關的交易被提交/回滾之後它啓動

這意味着您的會話將在交易e ither承諾或回滾。

正如我假設您使用spring來管理交易,那麼設置hibernate.current_session_context_class永遠不是件好事。默認情況下,spring將使用CurrentSessionContext

現在,您已經在current_session_context_class中使用了線程。然後爲自己的津津有味,我建議

try{ 
    //... your code 
} catch(HibernateException ex) { 
    LOG.error(ex); 
    session.getTransaction().rollback(); 
    throw ex; 
} finally { 
    if(session.isOpen()){ //I don't think this will return true in any case but still for your satisfaction you could do this 
     session.close(); 
    } 
} 

更新:

從聊天使用後在Spring數據源的bean)的配置,而不是SessionFactory的

<max-pool-size>50</max-pool-size> 
<query-timeout>500</query-timeout> 
+0

那麼爲什麼我會在一段時間後關閉連接錯誤?:/ – gohil90

相關問題