Shutdown ExecutorService gracefully in webapp? Shutdown ExecutorService gracefully in webapp? multithreading multithreading

Shutdown ExecutorService gracefully in webapp?


Shutdown hook is not a good approach in Tomcat because:

  • it will close the pool too late (on shutdown), Tomcat will already warn you about not closed resources

  • you actually want to shutdown that pool when application is undeployed so that redeployment works (otherwise each application will create new pool and they will all be closed only on complete shutdown)

  • shutting down the thread pool might take some time (see below), shutdown hook should be as fast as possible

Much better place is ServletContextListener.contextDestroyed(). Remember you have to both shutdownNow() the pool (to cancel running and reject new tasks) and awaitTermination() to wait for already running tasks to finish and all threads to stop.


In addition to what Tomasz suggested you can also use CachedThreadPool

Threads that have not been used for sixty seconds are terminated and removed from the cache. Thus, a pool that remains idle for long enough will not consume any resources

So a very good solution would be use CachedThreadPool and shutdown it in ServletContextListener.contextDestroyed().