Tomcat6.0的Thisisverylikelytocreateamemoryleak異常

從Apache Tomcat 5.5升級到6.0,一般不用太大的修改,原有的Web Application就能繼續運做。不過在server.xml中設定MySQL Datasource,卻出現一串惱人的警告訊息: 

2010/8/6 下午 01:54:11 org.apache.catalina.loader.WebappClassLoader clearReferencesJdbc 
嚴重的: The web application [/] registered the JBDC driver [com.mysql.jdbc.Driver] but failed to unregister it when the web application was stopped. To prevent a memory leak, the JDBC Driver has been forcibly unregistered. 
2010/8/6 下午 01:54:11 org.apache.catalina.loader.WebappClassLoader clearReferencesThreads 
嚴重的: The web application [/] appears to have started a thread named [Timer-0] but has failed to stop it. This is very likely to create a memory leak. 
2010/8/6 下午 01:54:11 org.apache.catalina.loader.WebappClassLoader clearReferencesThreads 
嚴重的: The web application [/] appears to have started a thread named [MySQL Statement Cancellation Timer] but has failed to stop it. This is very likely to create a memory leak. 

更新MySQL Connector/J至最新版也沒用,彷佛是Tomcat 6.0對於Memory Leak的防範變得比較雞婆智慧,才會多了這樣的警告。 

既然被列為嚴重程度的警告,當然就不能視而不見,解決的方法並不難,只是要把本來設定在區段中的搬到,修改方式以下。 

1. 將<Resource name="jdbc/NAME" auth="Container" type="javax.sql.DataSource" ... /> 整塊剪下,再貼到 <GlobalNamingResources> ... </GlobalNamingResources> 之間。 

2. 在本來Resource標籤的位置加入<ResourceLink global="jdbc/NAME" name="jdbc/NAME" type="javax.sql.DataSource" /> 

2011-11-09 10:40 tomcat memory leak 在tomcat(版本6.0.33)的 catalina.out中發現大量memory leak的日誌 

org.apache.catalina.loader.WebappClassLoader clearThreadLocalMap 

SEVERE: The web application [] created a ThreadLocal with key of type [com.opensymphony.xwork2.inject.ContainerImpl$10] (value [com.opensymphony.xwork2.inject.ContainerImpl$10@2618d45f]) and a value of type [java.lang.Object[]] (value [[Ljava.lang.Object;@51dce88]) but failed to remove it when the web application was stopped. This is very likely to create a memory leak. 

這個是因爲tomcat6.0.24之後的版本有加一個監控memory leak的listener 在tomcathome/conf/server.xml 

<!-- Prevent memory leaks due to use of particular java/javax APIs--> 

<Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener" /> 

可是這個監控有bug才致使的誤報 

解決方式任選一種 1 把tomcat降級爲6.0.24如下的版本 

2 將tomcat升級爲7.0.6以上的版本 

3 在server.xml中去掉JreMemoryLeakPreventionListener的listener 

http://wiki.apache.org/tomcat/MemoryLeakProtection
相關文章
相關標籤/搜索