欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

tomcat內存溢出問題解決經歷

 更新時間:2019年09月17日 09:21:31   作者:冰湖一角  
這篇文章主要介紹了tomcat內存溢出問題解決經歷,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下

前一段時間提交了一個產品版本給測試人員測試,測試結果簡直出人意料!

測試一段時間后頁面就卡死了,當時根據這個現(xiàn)象下意識的懷疑是卡到數據庫這一層,然后查看數據庫連接相關的參數,如意料之中的相似,連接數太多了!當把數據庫連接數解決后,本以為這個bug解決了,但是...

測試一段時間后頁面又卡死了?。?!

打開任務管理器,發(fā)現(xiàn)tomcat內存超過了1.5G,而且tomcat關不掉!是什么原因導致的呢?左思右想之后,想到了一個可能會導致tomcat內存上漲的點,那就是多線程,然后翻代碼找線程池的配置,發(fā)現(xiàn)也沒什么可疑之處。

那就先解決下tomcat關不掉的問題吧,百度...檢查代碼...幾十分鐘后找到了,在tomcat監(jiān)聽器的銷毀方法(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的日志發(fā)現(xiàn),頁面每一次調用后臺接口Spring的配置文件都會初始化一遍,也就是每次請求spring都會重新注入一次bean,而且占用的內存不會被回收!

然后我就想什么情況下會初始化spring的配置文件:tomcat啟動的時候;通過關鍵字new出來的時候,即

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

然后就全局搜索代碼找,果然在過濾器里找到了,每次接口來就會new一個對象,多可怕的代碼,在心里一直罵自己當時怎么想的!這次經歷我會引以為戒,記下來也是告訴自己以后不要再犯類似的問題。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • 實現(xiàn)將Web應用部署到Tomcat根目錄的三種方法

    實現(xiàn)將Web應用部署到Tomcat根目錄的三種方法

    本篇文章主要介紹了實現(xiàn)將Web應用部署到Tomcat根目錄的三種方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-05-05
  • tomcat虛擬路徑的配置方法匯總

    tomcat虛擬路徑的配置方法匯總

    本文給大家簡單匯總介紹了tomcat虛擬路徑的配置方法,十分的簡單實用,有需要的小伙伴可以參考下。
    2016-01-01
  • 啟動tomcat時 錯誤: 代理拋出異常 : java.rmi.server.ExportException: Port already in use: 1099的解決辦法

    啟動tomcat時 錯誤: 代理拋出異常 : java.rmi.server.ExportException: Port

    這篇文章主要介紹了啟動tomcat時 錯誤: 代理拋出異常 : java.rmi.server.ExportException: Port already in use: 1099的解決辦法的相關資料,需要的朋友可以參考下
    2016-05-05
  • Win10配置tomcat環(huán)境變量教程圖解

    Win10配置tomcat環(huán)境變量教程圖解

    這篇文章主要介紹了Win10配置tomcat環(huán)境變量教程圖解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-07-07
  • window7下Tomcat7.0安裝配置方法

    window7下Tomcat7.0安裝配置方法

    這篇文章主要介紹了window7下Tomcat7.0安裝配置方法,需要的朋友可以參考下
    2014-07-07
  • Tomcat核心組件及應用架構詳解

    Tomcat核心組件及應用架構詳解

    眾所周知Tomcat 就是一個 Servlet 容器,為了方便使用,他們具有http服務器的功能,所以Tomcat 就是一個“HTTP 服務器 + Servlet 容器”,我們也叫它們 Web 容器,今天重點給大家普及Tomcat核心組件及應用架構相關知識,感興趣的朋友一起了解下吧
    2021-05-05
  • 詳解Tomcat中Filter的執(zhí)行流程

    詳解Tomcat中Filter的執(zhí)行流程

    Filter是servlet規(guī)范中定義的java web組件, 在所有支持java web的容器中都可以使用,它是位于前端請求到servlet之間的一系列過濾器,也可以稱之為中間件,本文詳解介紹了Tomcat中Filter是怎樣執(zhí)行的,需要的朋友可以參考下
    2023-06-06
  • Linux系統(tǒng)centos7.X安裝tomcat8的圖文教程

    Linux系統(tǒng)centos7.X安裝tomcat8的圖文教程

    這篇文章主要介紹了Linux系統(tǒng)centos7.X安裝tomcat8的圖文教程,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-04-04
  • 如何提升Idea啟動速度與Tomcat日志亂碼問題

    如何提升Idea啟動速度與Tomcat日志亂碼問題

    這篇文章主要介紹了提升Idea啟動速度與Tomcat日志亂碼問題,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-03-03
  • 一文教你怎么選擇Tomcat對應的JDK版本

    一文教你怎么選擇Tomcat對應的JDK版本

    這篇文章主要給大家截介紹了怎么選擇Tomcat對應的JDK版本,如果不知道Tomcat的哪個版本應該對應哪個版本的JDK,可以參考借鑒本文,對大家的學習有一定的幫助
    2023-10-10

最新評論