We having multiple MemoryLeaks (found in the catalina.out), while reloading the context.
To clean up these threads, I created an implementation of ServletContextListener.
The contextInitialized()
method is successfully called when a context is created, because I can see the log entries.
But the contextDestroyed()
method is not called so my cleanup code is not invoked. Any ideas why this is happening?
Should I implement another Interface to be noticed when a context needs to be reloaded?
public class MyContextListener implements ServletContextListener {
private static final Logger log = Logger.getLogger(MyContextListener.class);
@Override
public void contextDestroyed(final ServletContextEvent arg0) {
MyContextListener.log.info("destroying Servlet Context");
//Do stuff
MyContextListener.log.info("Servlet Context destroyed");
}
@Override
public void contextInitialized(final ServletContextEvent arg0) {
try {
MyContextListener.log.info("Creating Servlet Context");
//Do stuff
} finally {
MyContextListener.log.info("Servlet Context created");
}
}
}
I had have the some problem, and I "fixed" it by System.out.println
.
@WebListener
public class App implements ServletContextListener {
private static final Logger logger = LoggerFactory.getLogger(App.class);
@Override
public void contextInitialized(ServletContextEvent sce) {
System.out.println("START");
logger.info("START");
}
@Override
public void contextDestroyed(ServletContextEvent sce) {
System.out.println("STOP");
logger.info("STOP");
}
}
log.txt:
[%thread] %-5level %logger{0}:%L - %msg%n
[localhost-startStop-1] INFO App:16 - START
stdout:
Commons Daemon procrun stdout initialized
START
STOP
It's mean that contextDestroyed
has been called, but the logger was stopped before. I used org.slf4j.Logger
To manage the logging live cicle (and so to fix the problem), see: Logging from servlet context destroyed event