Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

shutdown / undeploy tomcat from Servlet

I have an init servlet in Tomcat that loads critical data. Sometimes it is necessary to abort startup on certain errors.

how do i gracefully shutdown the deployed app/ the whole app server without calling System.exit(1)

i want to avoid calling the shutdown servlet via port, since this is not configured in my installation.

there may be tasks that need to be run from listeners on shutdown defined in web.xml

like image 901
Andreas Petersson Avatar asked Oct 08 '09 12:10

Andreas Petersson


1 Answers

First of all, you should never ever ever ever call System.exit() from within a servlet container, as there might be other applications running within the same process as yours, and it would be incredibly incorrect to forcibly kill the entire process.

Assuming your "init servlet" implements ServletContextListener, there is no formal way defined in the API/interface to signal to the servlet container "please shut down the app neatly". You could however throw some sort of RuntimeException from the contextInitialized() method, which in most containers (at least Tomcat) will stop the startup of your webapp and leave it in the "stopped" state. However I doubt that Tomcat will continue to call your shutdown listeners.

You might want to rethink your design so that your critical data / shutdown logic is not tied so tightly with the lifecycle of the servlet container.

like image 138
matt b Avatar answered Sep 30 '22 22:09

matt b