Я преследовал это в течение нескольких дней. Мы используем JAXB, воплощение солнца, в нашем приложении. При остановке Tomcat (6 или 7) в файле журнала каталогов регистрируется серьезная утечка памяти, в которой перечислены все классы JAXB, которые у нас есть в нашем приложении, два набора в двух разных пакетах.Утечки памяти Tomcat и JAXB
Я прошел через множество ссылок переполнения google и Stack. Я использовал JProfiler, который показывает мне, что Tomcat держится за Enums, когда они не используются, но это не должно быть проблемой. Все экземпляры marshaller или unmarshaller создаются локально и устанавливаются в null для агрессивного GC. Я гарантирую, что JAXBcontext имеет значение NULL, когда сервлеты уничтожаются, а также в моем контекстеDestroyed Я запускаю System.gc(); как было предложено избежать ошибки.
Но все же ошибка регистрируется. Я видел в презентации Tomcat, что это известная ошибка, поскольку JarURLConnection блокируется JAXBContext.newInstance(), очевидно, этого можно избежать, отключив кэширование, но это ничего не сделало для меня. http://people.apache.org/~markt/presentations/2010-11-04-Memory-Leaks-60mins.pdf
Любые другие предложения относительно того, как исправить эту утечку памяти в JAXB, работающем на Tomcat.
Это журнал ошибок:
SEVERE: The web application [/myApplication] created a ThreadLocal with key of type [com.sun.xml.bind.v2.ClassFactory$1] (value [[email protected]]) and a value of type [java.util.WeakHashMap] (value [{class [email protected]bb9f, class my.pack[email protected]1dc80063, class my.[email protected]359172db, class [email protected]6, class my[email protected]1c10945d, class [email protected]10, class [email protected]a7c8bd, class my.pa[email protected]716bf3b4, class my.packa[email protected]664ce898, class be.securit.trustbuilder.config.model.........}])
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.
17-sep-2013 15:21:45 org.apache.catalina.loader.WebappClassLoader checkThreadLocalMapForLeaks
Не работает для меня. Не могу понять, как движущаяся банка будет работать, так как они все равно загружаются одинаково ... –
Привет. Если ящик находится в области приложения и приложение повторно развернуто, то баночка загружается каждый раз, когда приложение развертывается, предыдущая загрузка классов не удаляется, так как они содержат слабую ссылку. Если банка находится в общей библиотеке, этого не происходит. Этот экземпляр действительно существует только в среде разработки, когда вы можете повторно развертывать приложения много раз. – Gurnard
Перемещение банки в систему. Путь Tomcat не исправляет ошибку в 'jaxb-impl'. ** Багги-библиотека по-прежнему забывает очищать локальные переменные потока **. Код проверки Tomcat предупреждает, только если ссылка объекта на загрузчик классов веб-приложений, если 'jaxb-impl' в ссылке' $ CATALINA_HOME/lib' приводит к загрузчику системного класса. – gavenkoa