ホームページ  >  記事  >  データベース  >  「com.mysql.jdbc.Exceptions.jdbc4.MySQLNonTransientConnectionException: 接続が閉じられた後は操作は許可されません」のトラブルシューティング方法を教えてください。

「com.mysql.jdbc.Exceptions.jdbc4.MySQLNonTransientConnectionException: 接続が閉じられた後は操作は許可されません」のトラブルシューティング方法を教えてください。

Patricia Arquette
Patricia Arquetteオリジナル
2024-10-25 17:10:02753ブラウズ

How to Troubleshoot

「com.mysql.jdbc.Exceptions.jdbc4.MySQLNonTransientConnectionException: 接続が閉じられた後は操作は許可されません」

問題:
アプリケーションをリモート サーバーにデプロイする場合、アプリケーションが 1 日以上実行されると MySQL 接続例外が発生します。例外メッセージには、接続が閉じられた後は操作が許可されないことが示されています。

原因:
この例外は、非アクティブなために接続が切断されたことが原因である可能性があります。 MySQL サーバーとクライアントのデフォルトのタイムアウト設定が短すぎる可能性があり、接続が途中で閉じられる可能性があります。

解決策:

1.サーバーとクライアントのタイムアウトを調整します

  • サーバー (MySQL 構成):

    • MySQL の「wait_timeout」値を増やします。データベース構成ファイル (my.cnf または my.ini)。この設定は、接続が閉じられるまでに非アクティブな状態を維持できる最大時間を決定します。
  • クライアント (Hibernate/JDBC 接続プール):

    • Hibernate 構成ファイルの「タイムアウト」プロパティを、推奨される 600 秒 (10 分) などのより高い値に設定します。これにより、Hibernate が接続をすぐに閉じないようにすることができます。

2.接続プールを有効にする

  • C3P0 や DBCP などの接続プールを使用して、データベース接続を効率的に管理します。接続プールは、事前に確立された接続のプールを作成および維持し、毎回接続を開いたり閉じたりするオーバーヘッドを削減します。
  • 接続プールを構成して、使用前に接続を自動的に確認して検証します。これにより、切断された接続が検出されて破棄され、例外が発生することがなくなります。

追加の対策:

  • 「autoReconnect」プロパティを設定します。 JDBC 接続プール設定の を true に設定します。これにより、接続が失敗したときにプールが自動的に接続を再確立できるようになります。
  • 「testConnectionOnCheckout」プロパティを使用して、使用する前に接続をテストします。これにより、古い接続が確実に検出され、プールから削除されます。
  • アプリケーション ログを定期的に監視して、潜在的な接続の問題を早期に検出します。

更新された Hibernate 構成:

提供された更新された Hibernate 構成ファイルは C3P0 接続プーリングを使用し、推奨設定が含まれています:

<hibernate-configuration>
  <session-factory>
    <!-- Database connection settings -->
    <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>

    <!-- Enable C3P0 connection pooling -->
    <property name="hibernate.connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property>
    <property name="c3p0.max_size">20</property>
    <property name="c3p0.min_size">5</property>
    <property name="c3p0.max_statements">0</property>
    <property name="c3p0.timeout">600</property>
    <property name="c3p0.idleConnectionTestPeriod">3600</property>
    <property name="c3p0.testConnectionOnCheckout">true</property>
  </session-factory>
</hibernate-configuration>

以上が「com.mysql.jdbc.Exceptions.jdbc4.MySQLNonTransientConnectionException: 接続が閉じられた後は操作は許可されません」のトラブルシューティング方法を教えてください。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。