「com.mysql.jdbc.Exceptions.jdbc4.MySQLNonTransientConnectionException: 接続が閉じられた後は操作は許可されません」
問題:
アプリケーションをリモート サーバーにデプロイする場合、アプリケーションが 1 日以上実行されると MySQL 接続例外が発生します。例外メッセージには、接続が閉じられた後は操作が許可されないことが示されています。
原因:
この例外は、非アクティブなために接続が切断されたことが原因である可能性があります。 MySQL サーバーとクライアントのデフォルトのタイムアウト設定が短すぎる可能性があり、接続が途中で閉じられる可能性があります。
解決策:
1.サーバーとクライアントのタイムアウトを調整します
サーバー (MySQL 構成):
クライアント (Hibernate/JDBC 接続プール):
2.接続プールを有効にする
追加の対策:
更新された 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 サイトの他の関連記事を参照してください。