【问题标题】:Hibernate - Database stops responding after a few queriesHibernate - 数据库在几次查询后停止响应
【发布时间】:2017-03-02 10:26:24
【问题描述】:

我使用 Hibernate 5.2.6 和 Tomcat 服务器来查询 MySQL 数据库。它可以正常工作,直到应用程序达到 7 次对数据库的调用。

无论调用什么(getAll()、find()、update()、自定义方法),7 次调用后数据库停止响应。这不是时间问题,因为我可以让应用程序运行几分钟而不会崩溃。但是一旦打了 7 个电话,它就会挂起。没有错误信息。

这是在服务器控制台中显示的查询 8,但没有来自数据库的响应:

这是我调用的两个服务(第一个是由 Hibernate 生成的;我创建了第二个):

@Override
public List<E> getAll() {
if (!currentSession().getTransaction().isActive()) {
    currentSession().beginTransaction();
}
List<E> ret = currentSession().createCriteria(daoType).list();
return ret;
}

@Override
public List<Subcategory> findByCategory(Category cat) {

if (!currentSession().getTransaction().isActive()) {
    currentSession().beginTransaction();
}

Query query = currentSession().createQuery("from Subcategory where category = :category");
query.setParameter("category", cat);
List<Subcategory> listSub = query.list();
return listSub;
}

我调用的服务有问题吗?还是这是服务器配置问题?

谢谢你帮助我!

编辑

这是我如何更改方法的示例:

@Override
public Audit findAuditById(int id) {

    if (!currentSession().getTransaction().isActive()) {
        currentSession().beginTransaction();
    }

    Query query = currentSession().createQuery("from Audit where idAudit = :id");
    query.setParameter("id", id);

    Audit audit = (Audit) query.uniqueResult();

    Hibernate.initialize(audit);
    currentSession().getTransaction().commit(); 
    currentSession().close();

    return audit;
}

这是我得到的“无会话”错误:

 faultCode: {http://schemas.xmlsoap.org/soap/envelope/}Server
 faultSubcode: 
 faultString: Marshalling Error: could not initialize proxy - no Session
 faultActor: 
 faultNode: 
 faultDetail: 
    {http://xml.apache.org/axis/}stackTrace:Marshalling Error: could not initialize proxy - no Session
    at org.apache.axis.message.SOAPFaultBuilder.createFault(SOAPFaultBuilder.java:222)
    at org.apache.axis.message.SOAPFaultBuilder.endElement(SOAPFaultBuilder.java:129)
    at org.apache.axis.encoding.DeserializationContext.endElement(DeserializationContext.java:1087)
    at com.sun.org.apache.xerces.internal.parsers.AbstractSAXParser.endElement(AbstractSAXParser.java:609)
    at com.sun.org.apache.xerces.internal.impl.XMLDocumentFragmentScannerImpl.scanEndElement(XMLDocumentFragmentScannerImpl.java:1782)
    at com.sun.org.apache.xerces.internal.impl.XMLDocumentFragmentScannerImpl$FragmentContentDriver.next(XMLDocumentFragmentScannerImpl.java:2967)
    at com.sun.org.apache.xerces.internal.impl.XMLDocumentScannerImpl.next(XMLDocumentScannerImpl.java:602)
    at com.sun.org.apache.xerces.internal.impl.XMLNSDocumentScannerImpl.next(XMLNSDocumentScannerImpl.java:112)
    at com.sun.org.apache.xerces.internal.impl.XMLDocumentFragmentScannerImpl.scanDocument(XMLDocumentFragmentScannerImpl.java:505)
    at com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(XML11Configuration.java:841)
    at com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(XML11Configuration.java:770)
    at com.sun.org.apache.xerces.internal.parsers.XMLParser.parse(XMLParser.java:141)
    at com.sun.org.apache.xerces.internal.parsers.AbstractSAXParser.parse(AbstractSAXParser.java:1213)
    at com.sun.org.apache.xerces.internal.jaxp.SAXParserImpl$JAXPSAXParser.parse(SAXParserImpl.java:643)
    at com.sun.org.apache.xerces.internal.jaxp.SAXParserImpl.parse(SAXParserImpl.java:327)
    at org.apache.axis.encoding.DeserializationContext.parse(DeserializationContext.java:227)
    at org.apache.axis.SOAPPart.getAsSOAPEnvelope(SOAPPart.java:696)
    at org.apache.axis.Message.getSOAPEnvelope(Message.java:435)
    at org.apache.axis.handlers.soap.MustUnderstandChecker.invoke(MustUnderstandChecker.java:62)
    at org.apache.axis.client.AxisClient.invoke(AxisClient.java:206)
    at org.apache.axis.client.Call.invokeEngine(Call.java:2784)
    at org.apache.axis.client.Call.invoke(Call.java:2767)
    at org.apache.axis.client.Call.invoke(Call.java:2443)
    at org.apache.axis.client.Call.invoke(Call.java:2366)
    at org.apache.axis.client.Call.invoke(Call.java:1812)
    at com.safran.engineering.esurvey.ws.impl.EsurveyWebServiceImplServiceSoapBindingStub.getAuditById(EsurveyWebServiceImplServiceSoapBindingStub.java:411)
    at model.impl.ImpGUI_Home.getAuditById(ImpGUI_Home.java:160)
    at model.Abstract_Home.lambda$1(Abstract_Home.java:77)
    at com.sun.javafx.event.CompositeEventHandler.dispatchBubblingEvent(CompositeEventHandler.java:86)
    at com.sun.javafx.event.EventHandlerManager.dispatchBubblingEvent(EventHandlerManager.java:238)
    at com.sun.javafx.event.EventHandlerManager.dispatchBubblingEvent(EventHandlerManager.java:191)
    at com.sun.javafx.event.CompositeEventDispatcher.dispatchBubblingEvent(CompositeEventDispatcher.java:59)
    at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:58)
    at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114)
    at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56)
    at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114)
    at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56)
    at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114)
    at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56)
    at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114)
    at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56)
    at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114)
    at com.sun.javafx.event.EventUtil.fireEventImpl(EventUtil.java:74)
    at com.sun.javafx.event.EventUtil.fireEvent(EventUtil.java:54)
    at javafx.event.Event.fireEvent(Event.java:198)
    at javafx.scene.Scene$ClickGenerator.postProcess(Scene.java:3470)
    at javafx.scene.Scene$ClickGenerator.access$8100(Scene.java:3398)
    at javafx.scene.Scene$MouseHandler.process(Scene.java:3766)
    at javafx.scene.Scene$MouseHandler.access$1500(Scene.java:3485)
    at javafx.scene.Scene.impl_processMouseEvent(Scene.java:1762)
    at javafx.scene.Scene$ScenePeerListener.mouseEvent(Scene.java:2494)
    at com.sun.javafx.tk.quantum.GlassViewEventHandler$MouseEventNotification.run(GlassViewEventHandler.java:380)
    at com.sun.javafx.tk.quantum.GlassViewEventHandler$MouseEventNotification.run(GlassViewEventHandler.java:294)
    at java.security.AccessController.doPrivileged(Native Method)
    at com.sun.javafx.tk.quantum.GlassViewEventHandler.lambda$handleMouseEvent$354(GlassViewEventHandler.java:416)
    at com.sun.javafx.tk.quantum.QuantumToolkit.runWithoutRenderLock(QuantumToolkit.java:389)
    at com.sun.javafx.tk.quantum.GlassViewEventHandler.handleMouseEvent(GlassViewEventHandler.java:415)
    at com.sun.glass.ui.View.handleMouseEvent(View.java:555)
    at com.sun.glass.ui.View.notifyMouse(View.java:937)
    at com.sun.glass.ui.win.WinApplication._runLoop(Native Method)
    at com.sun.glass.ui.win.WinApplication.lambda$null$148(WinApplication.java:191)
    at java.lang.Thread.run(Thread.java:745)

【问题讨论】:

  • 你不应该在某处提交()事务吗?
  • 你的连接池大小是 6 吗?
  • @user993553 我刚刚在我的服务的返回语句之前添加了一个 commit(),我收到了这个错误:“编组错误:无法初始化代理 - 没有会话”。这是我应该放置 commit() 的地方吗?
  • @Firilou,正如第一条评论中提到的,您需要提交在方法开始时已经启动的事务。每当你遇到这种问题,db没有响应,没有异常等等,大多数时候,你正在查询的表被之前的某个查询锁定了。在这种情况下,即使使用查询浏览器,您也无法在 Locked 表上触发任何查询。

标签: java hibernate jakarta-ee


【解决方案1】:

如果您所做的只是检索一个列表,那么您就不需要启动事务。只有在删除、更新或插入记录时才需要事务。一般来说,如果您正在启动事务,那么(大部分)在同一个代码块中我希望看到提交或回滚。我不确定 MySQL 如何或是否支持嵌套事务,所以这可能是导致问题的原因。

或者,如果 MySQL 本身正在停止(如果您无法从 MySQL Workbench 连接到它,您会知道,因为需要重新启动的不仅仅是您的应用程序),那么查看 mysql 生成的日志文件,因为这可能会提供有关原因的线索。如果出现硬件错误,这可能只是一个问题,但这只是一种感觉。

【讨论】:

    【解决方案2】:

    正如 Brian 所说,选择查询不需要事务。

    如果您仍然想拥有它们,那么您需要提交事务并关闭会话。然后调用initialize方法避免延迟加载问题。

        @Override
    public List<E> getAll() {
        if (!currentSession().getTransaction().isActive()) {
            currentSession().beginTransaction();
        }
        List<E> ret = currentSession().createCriteria(daoType).list();
        // Call initiliaze to avoid lazy loading exception.
        Hibernate.initialze(ret);
        // You need to commit the transaction & close the session.
        currentSession().getTransaction().commit(); 
        currentSession().close();
        return ret;
    }
    

    【讨论】:

    • 我尝试使用您的代码更改我的方法,但我仍然收到此错误:“编组错误:无法初始化代理 - 无会话”。另外,当我删除事务部分(因为我不需要它)时,它说我无法在没有事务的情况下创建查询。有什么提示吗?
    • 编辑您的问题并发布代理的完整堆栈跟踪 - 没有会话,问题。
    猜你喜欢
    • 2020-04-02
    • 1970-01-01
    • 2013-10-03
    • 2012-09-20
    • 2014-10-16
    • 1970-01-01
    • 2023-03-03
    • 1970-01-01
    • 2021-04-06
    相关资源
    最近更新 更多