I am studying for the Spring Core certification and I have some dount about on this question finded into the provided study material:
What is the preferred way to close an application context?
I know that if I have something like this:
ConfigurableApplicationContext context = …
// Destroy the application
context.close();
by the use of the close() method on the context objet the ApplicationContext is closed and the application is destroyed.
But I think that this is not the best way that I have to do it.
Reading the official documentation I find that I can also do something like this:
context.registerShutdownHook();
that register a Shutdown Hook with the JVM so it is the JVM that will trigger Spring's close phase before JVM exits. So on JVM exit, Spring's close phase will execute.
On the documentation I can read that: usually not possible to call context.close()
because many applications (web applications) run indefinitely But what exactly means this last assertion? why web application run indefinitely?
So my questions are:
- Can I use this second way to close an application context also with not web application?
- Is it prefered respect the
context.close()
?
Tnx
As you are aware that
ContextLoaderListener
is the one that takes care of initializing and destroying your ApplicationContext, when you shutdown your server, that ContextLoaderListener'scontextDestroyed
method is invoked.In that
closeWebApplicationContext
, they actually call theclose
method on ApplicationContext like thisThis is straight from
spring-web-4.1.5.jar
. As it is evident from here, they useclose
to destroy ApplicationContext in web applications.But
registerShutdownHook
is used to explicitly shut down IoC container in non-web applications something like a standalone desktop application, specially when you're creating the ApplicationContext manually from ClassPathXmlApplicationContext (or) FileSystemXmlApplicationContext (or) some other types.This is done to release all resources used by your spring application and to call destroy method on your spring beans if any.
A web application will run as long as the application server that deploys it runs. It is up to the application server (and not to you) to correctly start and stop your application. This means that when the application server is stopped, the servlet context is destroyed. In a Spring application, the
ContextLoaderListener
class registered inweb.xml
listens to this event (context destroyed) to properly close the Spring context.When using Spring outside of an application server (like a standalone application), it is up to you to correctly stop the Spring context. As you said, this can be done by explicitly calling
context.close()
or registering a shutdown hook (context.registerShutdownHook()
) that makes this call for you.