Корректная настройка Java 8 для выгрузки классов (очистка Metaspace) / cxf
Я создаю динамические клиенты CXF в моем приложении.
Вот фрагмент кода создания клиента:
JaxWsDynamicClientFactory factory = JaxWsDynamicClientFactory.newInstance();
Client client = factory.createClient("wsdl/hello.wsdl");
Теперь, когда я настраиваю тестовое приложение с этими параметрами
java -Djava.io.tmpdir=/tmp/cxf -XX:MetaspaceSize=12m -XX:MaxMetaspaceSize=24m -XX:MaxMetaspaceFreeRatio=80 -XX:MinMetaspaceFreeRatio=40 -XX:+UnlockDiagnosticVMOptions -XX:NativeMemoryTracking=sums=200 -XX:+ParallelRefProcEnabled -XX:+AggressiveOpts -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/tmp/hdump.hprof -XshowSettings -jar classloader-leak.jar
и выполнить создание клиента в цикле, я получаю java.lang.OutOfMemoryError: исключение Metaspace. Я не знаю, почему не выгружаются классы / не очищается метасоль. Если кто-то может мне помочь, вот мой тестовый проект. Просто соберите (mvn clean package) и выполните с командной строкой, как я сделал.
Я использую JDK8u77.
1 ответ
Решение
Я думаю, что нашел проблему в CXF. Проблема в том, что URLClassLoader, который создается внутри JaxWsDynamicClientFactory.createClient(), никогда не уничтожается.