Spring Framework Event Handling: Difference between revisions

From NovaOrdis Knowledge Base
Jump to navigation Jump to search
Line 18: Line 18:


Events are instances extending [https://docs.spring.io/spring-framework/docs/current/javadoc-api/org/springframework/context/ApplicationEvent.html ApplicationEvent].
Events are instances extending [https://docs.spring.io/spring-framework/docs/current/javadoc-api/org/springframework/context/ApplicationEvent.html ApplicationEvent].
==Standard Events==
* ContextStartedEvent
* ContextStoppedEvent


==Custom Event==
==Custom Event==

Revision as of 20:58, 23 November 2018

External

Internal

Overview

One of application context's capabilities is to handle events. The events are by default synchronous, which has a few advantages, one of them being the fact that the listener is able to participated in the publisher's transaction context.

Threading Consideration

Spring event handling is single threaded and synchronous in nature. If an event is published, until and unless all receivers get the message, the processes are blocked and the flow will not continue.

Event

Events are instances extending ApplicationEvent.

Standard Events

  • ContextStartedEvent
  • ContextStoppedEvent

Custom Event

Publisher

Events can be published using publishers. Any custom publisher should inject an ApplicationEventPublisher object.

Application Event Listener

Listeners should implement the ApplicationListener interface.