java - 高并發情況下Hibernate添加操作時部分線程SessionException: Session is closed!
問題描述
Servlet + hibernate在高并發情況下部分線程會出現org.hibernate.SessionException: Session is closed!,但是在單線程情況下不會出現。
org.hibernate.SessionException: Session is closed! at org.hibernate.impl.AbstractSessionImpl.errorIfClosed(AbstractSessionImpl.java:72) at org.hibernate.impl.SessionImpl.beginTransaction(SessionImpl.java:1466) at sun.reflect.GeneratedMethodAccessor18.invoke(Unknown Source) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:498) at org.hibernate.context.ThreadLocalSessionContext$TransactionProtectionWrapper.invoke(ThreadLocalSessionContext.java:345) at com.sun.proxy.$Proxy6.beginTransaction(Unknown Source) at cn.com.thit.pis.usermanager.dao.BaseDAO.queryByMainKey(BaseDAO.java:136) at cn.com.thit.pis.usermanager.service.PhoneService.Register(PhoneService.java:137) at cn.com.thit.pis.usermanager.servlet.Register.doGet(Register.java:52) at javax.servlet.http.HttpServlet.service(HttpServlet.java:621) at javax.servlet.http.HttpServlet.service(HttpServlet.java:728) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:51) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:222) at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:123) at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:502) at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:171) at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100) at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:953) at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118) at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:408) at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1041) at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:603) at org.apache.tomcat.util.net.AprEndpoint$SocketProcessor.doRun(AprEndpoint.java:2430) at org.apache.tomcat.util.net.AprEndpoint$SocketProcessor.run(AprEndpoint.java:2419) at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) at java.lang.Thread.run(Thread.java:745)
BaseDAO.java
public UserEntity queryByMainKey(long phone) {int retry = 0;entity = new UserEntity();session = factory.getCurrentSession();transaction = session.beginTransaction();while (retry++ < 3) { try {//if(!session.isOpen()) session.beginTransaction();Query q = session.createQuery('from UserEntity where phone=?');q.setLong(0, phone);if (q.list() == null || q.list().size() == 0) { return null;}entity.Clone((UserEntity) q.list().get(0));return entity; } catch (Exception e) {e.printStackTrace();continue; }}return null; }
問題解答
回答1:連接池配少了吧
回答2:解決了,將代碼改成如下即可
public UserEntity queryByMainKey(long phone) {int retry = 0;entity = new UserEntity();Session session = factory.getCurrentSession();Transaction transaction = session.beginTransaction();while (retry++ < 3) { try {//if(!session.isOpen()) session.beginTransaction();Query q = session.createQuery('from UserEntity where phone=?');q.setLong(0, phone);if (q.list() == null || q.list().size() == 0) { return null;}entity.Clone((UserEntity) q.list().get(0));return entity; } catch (Exception e) {e.printStackTrace();continue; }}return null; }
相關文章:
1. objective-c - iOS開發支付寶和微信支付完成為什么跳轉到了之前開發的一個app?2. mysql優化 - 關于mysql分區3. 請教各位大佬,瀏覽器點 提交實例為什么沒有反應4. 致命錯誤: Class ’appfacadeTest’ not found5. javascript - ionic2 input autofocus 電腦成功,iOS手機鍵盤不彈出6. python - 管道符和ssh傳文件7. css - 移動端字體設置問題8. css - 求推薦適用于vue2的框架 像bootstrap這種類型的9. html5 - 如何實現帶陰影的不規則容器?10. javascript - 循環嵌套多個promise應該如何實現?
