プロダクションコードからこのエラーが発生しました:
com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: サーバーから正常に受信された最後のパケットは 36940 秒前でした。サーバーに正常に送信された最後のパケットは 36940 秒前で、サーバーが構成した 'wait_timeout' の値よりも長くなっています。この問題を回避するには、アプリケーションで使用する前に接続の有効性を期限切れにするかテストするか、クライアント タイムアウトのサーバー設定値を増やすか、Connector/J 接続プロパティ 'autoReconnect=true' を使用することを検討する必要があります。
そして今、問題をローカルで再現して修正しようとしています。次のように春のコンテキストをセットアップします。
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"
destroy-method="close" p:driverClass="com.mysql.jdbc.Driver"
p:jdbcUrl="jdbc:mysql://localhost:3306/test?useUnicode=yes&characterEncoding=UTF-8&"
p:idleConnectionTestPeriod="120" p:initialPoolSize="1" p:maxIdleTime="1800"
p:maxPoolSize="1" p:minPoolSize="1" p:checkoutTimeout="1000"
/>
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource" ref="dataSource"/>
<property name="hibernateProperties">
<value>
hibernate.connection.provider_class = org.hibernate.connection.C3P0ConnectionProvider
hibernate.dialect=org.hibernate.dialect.MySQL5Dialect
hibernate.default_schema=platform_server_original
hibernate.show_sql=false
</value>
</property>
<property name="mappingResources">
<list>
<value>sometables.hbm.xml</value>
</list>
</property>
</bean>
次に、mysqlのwait_timeoutを10秒に設定し、テストを実行します。これは、基本的に接続を開き、クエリを実行して閉じ、プールに戻り、スレッドを15秒間スリープさせてから、再度接続を開きます、もう一度クエリを実行すると、壊れます。ただし、同様のエラーのみが発生しました。
com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: 通信リンク障害
サーバーに送信された最後のパケットは 16 ミリ秒前です。
では、これら 2 つのエラーは同じものなのだろうか、それとも異なるものなのだろうか? 私はいくつかの調査を行いましたが、両方のエラーが同じ解決策に至ったようです:プロパティ「testConnectionOnCheckout = true」を使用しています。ただし、c3p0 doc によると、これは非常にコストのかかるチェックです。「idleConnectionTestPeriod」の使用を推奨していますが、私はすでに 120 秒に設定しています。アイドル状態の接続を適切に検証できるようにするには、どの値を使用すればよいですか?
だから私は基本的に2つのことを尋ねています:
- 製品コードで発生したエラーを再現するにはどうすればよいですか?
- どうすれば修正できますか?
ありがとう!