Classloader Leak Prevention library
If you want to avoid the dreaded java.lang.OutOfMemoryError: Metaspace
/ PermGen space
, just include this library into your Java EE application, and add this context listener in your web.xml
:
<listener>
<listener-class>se.jiderhamn.classloader.leak.prevention.ClassLoaderLeakPreventor</listener-class>
</listener>
It makes sense to keep this listener "outermost" (initializing first, destroying last), so you should normally declare it before any other listeners in web.xml.
To learn more about classloader leaks, their causes, types, ways to find them and known offenders, see blog series here: http://java.jiderhamn.se/category/classloader-leaks/
Maven
The library is available in Maven Central with the following details:
<dependency>
<groupId>se.jiderhamn</groupId>
<artifactId>classloader-leak-prevention</artifactId>
<version>1.15.3</version>
</dependency>
Configuration
The context listener has a number of settings that can be configured with context parameters in web.xml
:
<context-param>
<param-name>ClassLoaderLeakPreventor.stopThreads</param-name>
<param-value>false</param-value>
</context-param>
The available settings are
Parameter name | Default value | Description |
---|
ClassLoaderLeakPreventor.stopThreads | true | Should threads tied to the web app classloader be forced to stop at application shutdown? |
ClassLoaderLeakPreventor.stopTimerThreads | true | Should Timer threads tied to the web app classloader be forced to stop at application shutdown? |
ClassLoaderLeakPreventor.executeShutdownHooks | true | Should shutdown hooks registered from the application be executed at application shutdown? |
ClassLoaderLeakPreventor.startOracleTimeoutThread | true |
Should the oracle.jdbc.driver.OracleTimeoutPollingThread thread be forced to start with system ClassLoader,
in case Oracle JDBC driver is present? This is normally a good idea, but can be disabled in case the Oracle JDBC
driver is not used even though it is on the classpath.
|
ClassLoaderLeakPreventor.threadWaitMs | 5000 (5 seconds) | No of milliseconds to wait for threads to finish execution, before stopping them. |
ClassLoaderLeakPreventor.shutdownHookWaitMs | 10000 (10 seconds) |
No of milliseconds to wait for shutdown hooks to finish execution, before stopping them.
If set to -1 there will be no waiting at all, but Thread is allowed to run until finished.
|
Classloader leak detection / test framework
The test framework now has its own Maven module and its own documentation, see classloader-leak-test-framework
License
This project is licensed under the Apache 2 license, which allows you to include modified versions of the code in your distributed software, without having to release your source code.