Heim > Datenbank > MySQL-Tutorial > Hauptteil

Wie behebe ich „MySQLNonTransientConnectionException: Nach dem Schließen der Verbindung sind keine Vorgänge zulässig' in Remote-Anwendungen?

Linda Hamilton
Freigeben: 2024-10-30 13:11:02
Original
579 Leute haben es durchsucht

How to Fix

MySQL Non-Transient Connection Exception

Problem:

Beim Remote-Bereitstellen einer Anwendung tritt die Ausnahme „com.mysql „.jdbc.Exceptions.jdbc4.MySQLNonTransientConnectionException: Keine Operationen zulässig, nachdem die Verbindung geschlossen wurde“ tritt nach der Anwendung auf läuft über einen Tag.

Ursache:

Der Fehler wird durch eine geschlossene Verbindung verursacht.

Mögliche Lösungen:

  1. Verbindung Pooling:

    Das integrierte Verbindungspooling von Hibernate ist begrenzt. Erwägen Sie die Verwendung einer Verbindungspooling-Lösung eines Drittanbieters wie C3P0.

    <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>
    Nach dem Login kopieren
  2. Testen Sie die Verbindung vor der Verwendung:

    Erstellen Sie eine „c3p0. Properties“-Datei im Stammverzeichnis des Klassenpfads mit der folgenden Eigenschaft:

    <code class="properties">c3p0.testConnectionOnCheckout=true</code>
    Nach dem Login kopieren

    Dadurch wird jede Verbindung getestet Dies kann dabei helfen, fehlerhafte Verbindungen zu identifizieren und zu schließen.

Aktualisierte hibernate.cfg.xml-Konfiguration:

<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>
Nach dem Login kopieren

Hinweis:Testen Sie alle Konfigurationsänderungen immer in einer Entwicklungs- oder Staging-Umgebung, bevor Sie sie in der Produktion bereitstellen.

Das obige ist der detaillierte Inhalt vonWie behebe ich „MySQLNonTransientConnectionException: Nach dem Schließen der Verbindung sind keine Vorgänge zulässig' in Remote-Anwendungen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!