專家訪談:Tomcat 7的內(nèi)存泄漏保護
今天上午51CTO為網(wǎng)友第一時間對“Tomcat 7 RC4發(fā)布”進行了報道。Tomcat 7的內(nèi)存泄漏保護一直是關(guān)注,今年年初,DZone網(wǎng)站對Mark Thomas針對Tomcat 7的內(nèi)存泄漏保護的功能進行了采訪,Mark Thomas是SpringSource的首席軟件工程師,同時也是Tomcat的代碼提交負責(zé)人。
在Tomcat 7中引入了一項新的功能:內(nèi)存泄漏保護。該功能可以解決Web應(yīng)用中的很多種會導(dǎo)致內(nèi)存泄漏的問題,特別是在應(yīng)用重新加載時候的內(nèi)存釋放問題。
下面是具體訪談的內(nèi)容(水平有限,對內(nèi)容做了很多精簡,詳情請看英文版):
DZone:什么原因會導(dǎo)致Web應(yīng)用重新加載時的內(nèi)存泄漏,這個內(nèi)存泄漏是怎么表現(xiàn)出來的?
Mark Thomas:最直接的現(xiàn)象就是PermGen產(chǎn)生OutOfMemoryError的錯誤,然后Tomcat掛掉
PermGen space的全稱是Permanent Generation space,是指內(nèi)存的永久保存區(qū)域,如果你的WEB APP下都用了大量的第三方j(luò)ar,其大小超過了jvm默認的大小(4M)那么就會產(chǎn)生此錯誤信息了。
為了防止該問題的發(fā)生,必須保證重載時web應(yīng)用的類加載器沒有保存任何對象的引用。
DZone:請告訴我們Tomcat以前在重載時的內(nèi)存泄漏問題
Mark Thomas:Tomcat的這個問題在我加入這個項目之前就一直都存在
DZone:那么是不是所有Tomcat中會導(dǎo)致內(nèi)存泄漏問題的Bug都已經(jīng)修復(fù)了呢?
Mark Thomas:應(yīng)該說是我們已知的所有問題都已經(jīng)得到解決,可能還存在一些未知的問題。
Tomcat 的虛擬機內(nèi)存剖析
DZone:程序庫、Java API都有什么用的bug會導(dǎo)致內(nèi)存泄漏呢?
Mark Thomas:內(nèi)存泄漏問題都有相同的原因,例如在Web應(yīng)用的ClassLoader初始化一個對象,然后這個對象將自己的引用保存到某個實例或者Registry中,當(dāng)重載時從ClassLoader撤銷這個對象時,Registry引用的對象還在,這樣就會導(dǎo)致內(nèi)存泄漏。
一般程序庫可能存在內(nèi)存泄漏的地方有:
1.JDBC驅(qū)動注冊
2.一些日志框架
3.在ThreadLocal中保存對象,但是并不去刪除它
4.啟動了線程,但沒有停止它
而Java API存在內(nèi)存泄漏的地方包括:
1.使用javax.imageio API (the Google Web Toolkit can trigger this)
2.使用java.beans.Introspector.flushCaches() (Tomcat does this to prevent memory leaks caused by this caching)
3.使用XML解析器(the root cause is unknown due to a bug in the JRE)
4.使用RMI遠程方法調(diào)用(somewhat ironically, causes a leak related to the garbage collector)
5.從Jar文件中讀取資源
DZone:請告訴我們,Tomcat 7是如何處理這些問題的
Mark Thomas:問題的關(guān)鍵在于Tomcat 7的WebappClassLoader類的clearReferences()方法。
對于前面提到的Java API中存在問題,通過確保Tomcat核心第一次使用這些API,然后讓應(yīng)用去調(diào)用,來防止內(nèi)存泄漏。關(guān)于如何保護內(nèi)存泄漏,請看JreLeakPreventionListener class.
DZone:依你看來,在控制內(nèi)存泄漏方面,Tomcat 7比現(xiàn)有版本的Tomcat有多大的提升?
Mark Thomas:有顯著的提升,呵呵
DZone:Tomcat 7的開發(fā)進展如何,有一個確切的發(fā)布日期嗎?
Mark Thomas:Tomcat 7的開發(fā)進展非常順利,JSP和EL 2.2規(guī)范已經(jīng)實現(xiàn),Servlet 3.0的規(guī)范實現(xiàn)也接近完成。
DZone:關(guān)于Tomcat 7,你還有什么其他要補充的嗎?
【編輯推薦】