91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

tomcat內存溢出問題解決經歷

發布時間:2020-09-16 10:13:56 來源:腳本之家 閱讀:162 作者:冰湖一角 欄目:服務器

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

測試一段時間后頁面就卡死了,當時根據這個現象下意識的懷疑是卡到數據庫這一層,然后查看數據庫連接相關的參數,如意料之中的相似,連接數太多了!當把數據庫連接數解決后,本以為這個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一個對象,多可怕的代碼,在心里一直罵自己當時怎么想的!這次經歷我會引以為戒,記下來也是告訴自己以后不要再犯類似的問題。

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

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

濮阳县| 日喀则市| 旬阳县| 卫辉市| 唐海县| 襄垣县| 治县。| 义乌市| 勃利县| 湾仔区| 从化市| 永安市| 绥德县| 治县。| 右玉县| 咸丰县| 蛟河市| 苍梧县| 江都市| 凤凰县| 天水市| 桂林市| 泸水县| 将乐县| 乐业县| 定安县| 张家口市| 封丘县| 冕宁县| 裕民县| 东宁县| 海盐县| 新郑市| 河南省| 广灵县| 朝阳区| 于田县| 措勤县| 山东省| 建德市| 台东市|