如何修復遠端應用程式中的'MySQLNonTransientConnectionException:連接關閉後不允許執行任何操作”?

Linda Hamilton
發布: 2024-10-30 13:11:02
原創
580 人瀏覽過

How to Fix

MySQL 非瞬態連線異常

問題:

遠端部署應用程式時,出現異常「com.mysql 」應用程式運行一天多後,出現「.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: No actions allowed after connection close」的錯誤。

原因:

導致錯誤透過關閉連線。

潛在解決方案:

  1. 連接池:

    Hibernate>連接池:

    <code class="xml"><property name="connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property>
    <property name="c3p0.min_size">5</property>
    <property name="c3p0.max_size">20</property>
    <property name="c3p0.max_statements">50</property>
    <property name="c3p0.maxIdleTime">3600</property></code>
    登入後複製
  2. Hibernate 的內建有限的。考慮使用第三方連接池解決方案,例如 C3P0。
  3. 使用前測連線:

    <code class="properties">c3p0.testConnectionOnCheckout=true</code>
    登入後複製

    建立一個「c3p0.5」檔案。類路徑根目錄中的「properties」檔案具有以下屬性:

這將在使用每個連接之前對其進行測試,這可以幫助識別和關閉錯誤的連接。

<code class="xml"><property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="hibernate.connection.url">jdbc:mysql://localhost:3306/xyz</property>
<property name="hibernate.connection.username">root</property>
<property name="hibernate.connection.password">root</property>
<property name="hibernate.show_sql">false</property>
<property name="hibernate.current_session_context_class">thread</property>
<property name="hibernate.query.factory_class">org.hibernate.hql.ast.ASTQueryTranslatorFactory</property>

<property name="hibernate.c3p0.min_size">5</property>
<property name="hibernate.c3p0.max_size">20</property>
<property name="hibernate.c3p0.max_statements">50</property>

<property name="connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property>
<property name="c3p0.max_statements">0</property>
<property name="c3p0.maxIdleTimeExcessConnections">3600</property>
<property name="c3p0.idleConnectionTestPeriod">3600</property>
<property name="c3p0.maxIdleTime">3600</property></code>
登入後複製
更新了hibernate.cfg.xml 配置:

注意:注意: 在將設定更改部署到在生產環境之前,請務必在開發或暫存環境中測試任何配置變更.

以上是如何修復遠端應用程式中的'MySQLNonTransientConnectionException:連接關閉後不允許執行任何操作”?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!