Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 1626|回复: 0

tomcat重启警告:Abandoned connection cleanup thread 服务器宕机解决方案

[复制链接]
  • TA的每日心情
    奋斗
    2025-3-18 14:43
  • 签到天数: 805 天

    [LV.10]以坛为家III

    2053

    主题

    2111

    帖子

    73万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    731050
    发表于 2021-4-25 16:52:07 | 显示全部楼层 |阅读模式

    每次出现这个报错都会导致tomcat应用服务器停机

    报错信息:

    1 The web application [HelloWeb] appears to have started a thread named [Abandoned connection cleanup thread] but has failed to stop it. This is very likely to create a memory leak. Stack trace of thread:
    2          java.lang.Object.wait(Native Method)
    3          java.lang.ref.ReferenceQueue.remove(Unknown Source)
    4          com.mysql.jdbc.AbandonedConnectionCleanupThread.run(AbandonedConnectionCleanupThread.java:43)

    加了下面的java代码后就再也没有停过了。

     1 package cn.listener;
     2 
     3 import java.sql.Driver;
     4 import java.sql.DriverManager;
     5 import java.sql.SQLException;
     6 import java.util.Enumeration;
     7 
     8 import javax.servlet.ServletContextEvent;
     9 import javax.servlet.ServletContextListener;
    10 import javax.servlet.annotation.WebListener;
    11 
    12 import com.mysql.jdbc.AbandonedConnectionCleanupThread;
    13 
    14 
    15 @WebListener
    16 public class ContextFinalizer implements ServletContextListener {
    17 
    18     public void contextInitialized(ServletContextEvent sce) {
    19     }
    20 
    21     public void contextDestroyed(ServletContextEvent sce) {
    22         Enumeration<Driver> drivers = DriverManager.getDrivers();
    23         Driver d = null;
    24         while (drivers.hasMoreElements()) {
    25             try {
    26                 d = drivers.nextElement();
    27                 DriverManager.deregisterDriver(d);
    28                 System.out.println(String.format("ContextFinalizer:Driver %s deregistered", d));
    29             } catch (SQLException ex) {
    30                 System.out.println(String.format("ContextFinalizer:Error deregistering driver %s", d) + ":" + ex);
    31             }
    32         }
    33         try {
    34             AbandonedConnectionCleanupThread.shutdown();
    35         } catch (InterruptedException e) {
    36             System.out.println("ContextFinalizer:SEVERE problem cleaning up: " + e.getMessage());
    37             e.printStackTrace();
    38         }
    39     }
    40 }

    @WebListener,这个注解相当于在web.xml配置如下内容
    1   <listener>
    2     <listener-class>cn.listener.ContextFinalizer</listener-class>
    3   </listener>

     

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-4-21 21:00 , Processed in 0.058988 second(s), 29 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表