tomcat內(nèi)存溢出問題解決經(jīng)歷
前一段時(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í)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
實(shí)現(xiàn)將Web應(yīng)用部署到Tomcat根目錄的三種方法
本篇文章主要介紹了實(shí)現(xiàn)將Web應(yīng)用部署到Tomcat根目錄的三種方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-05-05啟動(dòng)tomcat時(shí) 錯(cuò)誤: 代理拋出異常 : java.rmi.server.ExportException: Port
這篇文章主要介紹了啟動(dòng)tomcat時(shí) 錯(cuò)誤: 代理拋出異常 : java.rmi.server.ExportException: Port already in use: 1099的解決辦法的相關(guān)資料,需要的朋友可以參考下2016-05-05Linux系統(tǒng)centos7.X安裝tomcat8的圖文教程
這篇文章主要介紹了Linux系統(tǒng)centos7.X安裝tomcat8的圖文教程,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-04-04如何提升Idea啟動(dòng)速度與Tomcat日志亂碼問題
這篇文章主要介紹了提升Idea啟動(dòng)速度與Tomcat日志亂碼問題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-03-03一文教你怎么選擇Tomcat對(duì)應(yīng)的JDK版本
這篇文章主要給大家截介紹了怎么選擇Tomcat對(duì)應(yīng)的JDK版本,如果不知道Tomcat的哪個(gè)版本應(yīng)該對(duì)應(yīng)哪個(gè)版本的JDK,可以參考借鑒本文,對(duì)大家的學(xué)習(xí)有一定的幫助2023-10-10