系统相关
首页 > 系统相关> > java-tomcat 7.0和jax-ws 2.2.5内存泄漏

java-tomcat 7.0和jax-ws 2.2.5内存泄漏

作者:互联网

我正在用tomcat和jax-ws构建ws.
当我停止我的应用程序时,通常是从eclipse重新部署时,我收到以下消息:

25-mar-2012 16.21.16 com.sun.xml.ws.transport.http.servlet.WSServletDelegate destroy
INFO: WSSERVLET15: JAX-WS servlet destroyed
25-mar-2012 16.21.16 com.sun.xml.ws.transport.http.servlet.WSServletContextListener contextDestroyed
INFO: WSSERVLET13: JAX-WS context listener destroyed
25-mar-2012 16.21.16 org.apache.catalina.loader.WebappClassLoader checkThreadLocalMapForLeaks
GRAVE: The web application [/xccm] created a ThreadLocal with key of type [com.sun.xml.ws.api.streaming.XMLStreamReaderFactory$Default$1] (value [com.sun.xml.ws.api.streaming.XMLStreamReaderFactory$Default$1@7edeaa13]) and a value of type [com.sun.xml.internal.stream.XMLInputFactoryImpl] (value [com.sun.xml.internal.stream.XMLInputFactoryImpl@4c700677]) but failed to remove it when the web application was stopped. Threads are going to be renewed over time to try and avoid a probable memory leak. 

用ClasspathHelper进行挖掘,我发现jaxws-rt.jar引用了com.sun.xml.ws.api.streaming.XMLStreamReaderFactory $Default $1

但是我没有在代码中明确使用任何jax-ws类,除了:

import javax.jws.WebParam;
import javax.jws.WebService;
import javax.xml.bind.JAXBContext;

据我所知,tomcat加载com.sun.xml.ws.transport.http.servlet.WSServlet(以及日志片段中的其他类).

任何想法如何解决这个问题?

谢谢

解决方法:

您使用的库(JAX-WS实现)创建了一个线程本地线程,其密钥的类型由您的Web应用程序类加载器加载.

这意味着无法对Web应用程序类加载器进行垃圾回收,因为只有在没有强烈引用其类实例的情况下,才可以对类加载器进行垃圾回收.多次重新部署后,您的JVM将耗尽perm gen空间.

真正的解决方法是侦听Web应用程序的生命周期,并在关闭线程时删除本地线程.但是,由于您不了解JAX-WS实现的内部,因此很难做到这一点.

另一个解决方案是将jaxws-rt.jar(以及可能与JAX-WS相关的其他JAR文件)添加到Tomcat安装的“ lib”目录中.在这种情况下,它们将由公共类加载器加载,并且当您重新部署Web应用程序时将不会重新加载它们.

标签:jax-ws,tomcat,memory-leaks,java
来源: https://codeday.me/bug/20191201/2081740.html