Bagaimana untuk Membetulkan \'MySQLNonTransientConnectionException: Tiada operasi dibenarkan selepas sambungan ditutup\' dalam Aplikasi Jauh?

Linda Hamilton
Lepaskan: 2024-10-30 13:11:02
asal
584 orang telah melayarinya

How to Fix

Pengecualian Sambungan Bukan Transien MySQL

Masalah:

Apabila menggunakan aplikasi dari jauh, pengecualian "com.mysql .jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: Tiada operasi dibenarkan selepas sambungan ditutup" berlaku selepas aplikasi berjalan selama lebih sehari.

Punca:

Ralat disebabkan melalui sambungan tertutup.

Penyelesaian Potensi:

  1. Pengumpulan Sambungan:

    Hibernate terbina- berhubung pengumpulan adalah terhad. Pertimbangkan untuk menggunakan penyelesaian pengumpulan sambungan pihak ketiga seperti 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>
    Salin selepas log masuk
  2. Uji Sambungan Sebelum Penggunaan:

    Buat "c3p0. properties" dalam akar classpath dengan sifat berikut:

    <code class="properties">c3p0.testConnectionOnCheckout=true</code>
    Salin selepas log masuk

    Ini akan menguji setiap sambungan sebelum menggunakannya, yang boleh membantu mengenal pasti dan menutup sambungan yang rosak.

Konfigurasi hibernate.cfg.xml yang dikemas kini:

<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>
Salin selepas log masuk

Nota: Sentiasa uji sebarang perubahan konfigurasi pada persekitaran pembangunan atau pementasan sebelum mengaturnya ke pengeluaran .

Atas ialah kandungan terperinci Bagaimana untuk Membetulkan \'MySQLNonTransientConnectionException: Tiada operasi dibenarkan selepas sambungan ditutup\' dalam Aplikasi Jauh?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!