十年網(wǎng)站開發(fā)經(jīng)驗 + 多家企業(yè)客戶 + 靠譜的建站團隊
量身定制 + 運營維護+專業(yè)推廣+無憂售后,網(wǎng)站問題一站解決
前一段時間提交了一個產(chǎn)品版本給測試人員測試,測試結(jié)果簡直出人意料!

測試一段時間后頁面就卡死了,當時根據(jù)這個現(xiàn)象下意識的懷疑是卡到數(shù)據(jù)庫這一層,然后查看數(shù)據(jù)庫連接相關(guān)的參數(shù),如意料之中的相似,連接數(shù)太多了!當把數(shù)據(jù)庫連接數(shù)解決后,本以為這個bug解決了,但是...
測試一段時間后頁面又卡死了?。?!
打開任務(wù)管理器,發(fā)現(xiàn)tomcat內(nèi)存超過了1.5G,而且tomcat關(guān)不掉!是什么原因?qū)е碌哪兀孔笏加蚁胫?,想到了一個可能會導致tomcat內(nèi)存上漲的點,那就是多線程,然后翻代碼找線程池的配置,發(fā)現(xiàn)也沒什么可疑之處。
那就先解決下tomcat關(guān)不掉的問題吧,百度...檢查代碼...幾十分鐘后找到了,在tomcat監(jiān)聽器的銷毀方法(contextDestroyed)里沒有關(guān)閉線程池,這種情況下,由于線程池沒法關(guān)閉,進而導致tomcat無法關(guān)閉的問題。
將代碼改為:
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("關(guān)閉tomcat,關(guān)閉線程池");
ClassPathXmlApplicationContext classPathXmlApplicationContext = new ClassPathXmlApplicationContext("classpath*:applicationContext.xml");
ThreadPoolTaskExecutor myTaskExecutor = (ThreadPoolTaskExecutor) classPathXmlApplicationContext.getBean("myTaskExecutor");
myTaskExecutor.shutdown();
}
}另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。