tomcat内存溢出问题解决经历

 更新时间:2019年09月17日 09:21:31   作者:冰湖一角  
这篇文章主要介绍了tomcat内存溢出问题解决经历,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

前一段时间提交了一个产品版本给测试人员测试,测试结果简直出人意料!

测试一段时间后页面就卡死了,当时根据这个现象下意识的怀疑是卡到数据库这一层,然后查看数据库连接相关的参数,如意料之中的相似,连接数太多了!当把数据库连接数解决后,本以为这个bug解决了,但是...

测试一段时间后页面又卡死了!!!

打开任务管理器,发现tomcat内存超过了1.5G,而且tomcat关不掉!是什么原因导致的呢?左思右想之后,想到了一个可能会导致tomcat内存上涨的点,那就是多线程,然后翻代码找线程池的配置,发现也没什么可疑之处。

那就先解决下tomcat关不掉的问题吧,百度...检查代码...几十分钟后找到了,在tomcat监听器的销毁方法(contextDestroyed)里没有关闭线程池,这种情况下,由于线程池没法关闭,进而导致tomcat无法关闭的问题。

将代码改为:

public class InitListener implements ServletContextListener{
  private Logger logger = Logger.getLogger(InitListener.class);
  @Override
  public void contextInitialized(ServletContextEvent sce) {
    logger.info("启动tomcat");
  }
  @Override
  public void contextDestroyed(ServletContextEvent sce) {
    logger.info("关闭tomcat,关闭线程池");
    ClassPathXmlApplicationContext classPathXmlApplicationContext = new ClassPathXmlApplicationContext("classpath*:applicationContext.xml");
    ThreadPoolTaskExecutor myTaskExecutor = (ThreadPoolTaskExecutor) classPathXmlApplicationContext.getBean("myTaskExecutor");
    myTaskExecutor.shutdown();
  }
}

好了,tomcat关不掉的问题是解决了。

接下来解决内存溢出的问题(先看日志):

查看tomcat的日志发现,页面每一次调用后台接口Spring的配置文件都会初始化一遍,也就是每次请求spring都会重新注入一次bean,而且占用的内存不会被回收!

然后我就想什么情况下会初始化spring的配置文件:tomcat启动的时候;通过关键字new出来的时候,即

ClassPathXmlApplicationContext classPathXmlApplicationContext = new ClassPathXmlApplicationContext("classpath*:applicationContext.xml");

然后就全局搜索代码找,果然在过滤器里找到了,每次接口来就会new一个对象,多可怕的代码,在心里一直骂自己当时怎么想的!这次经历我会引以为戒,记下来也是告诉自己以后不要再犯类似的问题。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Tomcat启动时JAR包报错Invalid byte tag in constant pool异常的解决方案

    Tomcat启动时JAR包报错Invalid byte tag in const

    在开发Java Web应用时,我们经常会使用Apache Tomcat作为 Servlet容器进行部署和测试,然而,在项目启动过程中,有时会遇到类似于“Invalid byte tag in constant pool”的异常,本文将详细分析这一问题的成因,并探讨几种有效的解决方案,需要的朋友可以参考下
    2024-10-10
  • 详解tomcat部署静态html网站方法

    详解tomcat部署静态html网站方法

    这篇文章主要介绍了tomcat部署静态html网站方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-06-06
  • 图解Linux下安装Tomcat服务器

    图解Linux下安装Tomcat服务器

    这篇文章主要以图文结合的方式为大家详细介绍了Linux下安装Tomcat服务器的详细过程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-10-10
  • tomcat 实现会话绑定的方法步骤

    tomcat 实现会话绑定的方法步骤

    这篇文章主要介绍了tomcat 实现会话绑定的方法步骤
    2024-03-03
  • tomcat设置gzip压缩的原理及配置方法

    tomcat设置gzip压缩的原理及配置方法

    这篇文章主要介绍了tomcat设置gzip压缩的原理及配置方法,需要的朋友可以参考下
    2017-10-10
  • 如何设置Tomcat的默认端口(图文)

    如何设置Tomcat的默认端口(图文)

    Tomcat安装时默认的端口设置的是8080,而http协议的默认端口是80,所以测试Tomcat时需要输入的网址为“http://localhost:8080”,若把Tomcat的端口设置为80,则直接输入“http://localhost”就能显示Tomcat默认主页,下面我们来分享下,方便需要的朋友
    2014-06-06
  • 解决Tomcat运行startup.bat闪退问题方法

    解决Tomcat运行startup.bat闪退问题方法

    这篇文章主要为大家介绍了解决Tomcat运行startup.bat闪退问题方法详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-12-12
  • Tomcat默认程序发布路径的使用与修改方法讲解

    Tomcat默认程序发布路径的使用与修改方法讲解

    今天小编就为大家分享一篇关于Tomcat默认程序发布路径的使用与修改方法讲解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-02-02
  • Nginx/Httpd反代tomcat配置教程

    Nginx/Httpd反代tomcat配置教程

    这篇文章主要介绍了Nginx/Httpd反代tomcat配置教程以及一些常见的反代服务器,本文通过图文的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-07-07
  • 一文搞懂如何部署启动多个tomcat并移植项目

    一文搞懂如何部署启动多个tomcat并移植项目

    本文给大家介绍部署启动多个tomcat并移植项目的操作方法,本文给大家介绍的非常详细,包括修改配置文件的方法也给大家列举出来了,具体内容详情跟随小编一起看看吧
    2021-06-06

最新评论