tomcatサーバダウンタイムソリューション
4309 ワード
エラーメッセージ:
java.lang.Object.wait(Native Method)
java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:143)
com.mysql.jdbc.AbandonedConnectionCleanupThread.run(AbandonedConnectionCleanupThread.java:43)
このエラーが発生するたびにtomcatアプリケーションサーバが停止し、次のjavaコードを追加してから停止しません.
解決策:
Javaコードの作成
ソリューションは、次のWebサイトを参照してください.https://stackoverflow.com/questions/25699985/the-web-application-appears-to-have-started-a-thread-named-abandoned-connect
もちろん、私がこのソリューションを参考にしたとき、mysql-connectionがバージョンが低すぎると上記のJavaコードが間違っていることに気づきました.mysql-connectionを高めることで.JAvaのバージョンでこの問題を解決できます
java.lang.Object.wait(Native Method)
java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:143)
com.mysql.jdbc.AbandonedConnectionCleanupThread.run(AbandonedConnectionCleanupThread.java:43)
このエラーが発生するたびにtomcatアプリケーションサーバが停止し、次のjavaコードを追加してから停止しません.
解決策:
Javaコードの作成
package cn.listener;
import java.sql.Driver;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.Enumeration;
import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;
import javax.servlet.annotation.WebListener;
import com.mysql.jdbc.AbandonedConnectionCleanupThread;
@WebListener
public class ContextFinalizer implements ServletContextListener {
public void contextInitialized(ServletContextEvent sce) {
}
public void contextDestroyed(ServletContextEvent sce) {
Enumeration drivers = DriverManager.getDrivers();
Driver d = null;
while (drivers.hasMoreElements()) {
try {
d = drivers.nextElement();
DriverManager.deregisterDriver(d);
System.out.println(String.format("ContextFinalizer:Driver %s deregistered", d));
} catch (SQLException ex) {
System.out.println(String.format("ContextFinalizer:Error deregistering driver %s", d) + ":" + ex);
}
}
try {
AbandonedConnectionCleanupThread.shutdown();
} catch (InterruptedException e) {
System.out.println("ContextFinalizer:SEVERE problem cleaning up: " + e.getMessage());
e.printStackTrace();
}
}
}
@WebListener, web.xml
<listener>
<listener-class>cn.listener.ContextFinalizerlistener-class>
listener>
ソリューションは、次のWebサイトを参照してください.https://stackoverflow.com/questions/25699985/the-web-application-appears-to-have-started-a-thread-named-abandoned-connect
もちろん、私がこのソリューションを参考にしたとき、mysql-connectionがバージョンが低すぎると上記のJavaコードが間違っていることに気づきました.mysql-connectionを高めることで.JAvaのバージョンでこの問題を解決できます