婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁(yè) > 知識(shí)庫(kù) > tomcat內(nèi)存溢出問題解決經(jīng)歷

tomcat內(nèi)存溢出問題解決經(jīng)歷

熱門標(biāo)簽:地圖標(biāo)注如何改成微信號(hào) 山東企業(yè)外呼系統(tǒng)公司 虛假地圖標(biāo)注 靈圖uu電子寵物店地圖標(biāo)注 400電話號(hào)碼辦理多少錢 濮陽(yáng)好的聯(lián)通400電話申請(qǐng) 地圖標(biāo)注黃河的位置 承德地圖標(biāo)注公司 百度地圖標(biāo)注公司位置要多少錢

前一段時(shí)間提交了一個(gè)產(chǎn)品版本給測(cè)試人員測(cè)試,測(cè)試結(jié)果簡(jiǎn)直出人意料!

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

測(cè)試一段時(shí)間后頁(yè)面又卡死了!!!

打開任務(wù)管理器,發(fā)現(xiàn)tomcat內(nèi)存超過了1.5G,而且tomcat關(guān)不掉!是什么原因?qū)е碌哪兀孔笏加蚁胫螅氲搅艘粋€(gè)可能會(huì)導(dǎo)致tomcat內(nèi)存上漲的點(diǎn),那就是多線程,然后翻代碼找線程池的配置,發(fā)現(xiàn)也沒什么可疑之處。

那就先解決下tomcat關(guān)不掉的問題吧,百度...檢查代碼...幾十分鐘后找到了,在tomcat監(jiān)聽器的銷毀方法(contextDestroyed)里沒有關(guān)閉線程池,這種情況下,由于線程池沒法關(guān)閉,進(jìn)而導(dǎo)致tomcat無法關(guān)閉的問題。

將代碼改為:

public class InitListener implements ServletContextListener{
  private Logger logger = Logger.getLogger(InitListener.class);
  @Override
  public void contextInitialized(ServletContextEvent sce) {
    logger.info("啟動(dòng)tomcat");
  }
  @Override
  public void contextDestroyed(ServletContextEvent sce) {
    logger.info("關(guān)閉tomcat,關(guān)閉線程池");
    ClassPathXmlApplicationContext classPathXmlApplicationContext = new ClassPathXmlApplicationContext("classpath*:applicationContext.xml");
    ThreadPoolTaskExecutor myTaskExecutor = (ThreadPoolTaskExecutor) classPathXmlApplicationContext.getBean("myTaskExecutor");
    myTaskExecutor.shutdown();
  }
}

好了,tomcat關(guān)不掉的問題是解決了。

接下來解決內(nèi)存溢出的問題(先看日志):

查看tomcat的日志發(fā)現(xiàn),頁(yè)面每一次調(diào)用后臺(tái)接口Spring的配置文件都會(huì)初始化一遍,也就是每次請(qǐng)求spring都會(huì)重新注入一次bean,而且占用的內(nèi)存不會(huì)被回收!

然后我就想什么情況下會(huì)初始化spring的配置文件:tomcat啟動(dòng)的時(shí)候;通過關(guān)鍵字new出來的時(shí)候,即

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

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

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

標(biāo)簽:樂山 泰安 上海 安康 福州 淮安 德宏 鷹潭

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《tomcat內(nèi)存溢出問題解決經(jīng)歷》,本文關(guān)鍵詞  tomcat,內(nèi)存,溢,出問題,解決,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《tomcat內(nèi)存溢出問題解決經(jīng)歷》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于tomcat內(nèi)存溢出問題解決經(jīng)歷的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 庆安县| 兰州市| 安新县| 和林格尔县| 平远县| 襄垣县| 广饶县| 盱眙县| 达尔| 红原县| 高州市| 徐闻县| 霍州市| 花垣县| 黔东| 盐城市| 普兰店市| 湖州市| 衡阳市| 邛崃市| 竹山县| 苍溪县| 苍梧县| 曲阜市| 探索| 德钦县| 独山县| 迭部县| 崇州市| 临洮县| 梓潼县| 凤翔县| 禄丰县| 张家口市| 大冶市| 兴文县| 漾濞| 鄂托克前旗| 汉川市| 大兴区| 新河县|