WAS v8.5 > Develop applications > Develop Asynchronous beans > Develop work objects, event listeners, and asynchronous scopes > Develop event listenersUse the application notification service
During the application lifetime, individual J2EE components (servlets or enterprise beans) within a single EAR file might need to signal each other. There is an event source in the java:comp namespace that is bound into all components within an EAR file that can be used for notification.
The JNDI name for this event source, in the java:comp namespace that is bound into all components within an EAR file, is:
java:comp/websphere/ApplicationNotificationService
Components within the same application can fire asynchronous events and register event listeners using this application notification service. Startup beans can be used to register these event listeners at application startup or they can be registered dynamically at run time.
To have your enterprise bean or servlet use the application notification service, write code similar to the following example:
InitialContext ic = new InitialContext(); EventSource appES = (EventSource) ic.lookup("java:comp/websphere/ApplicationNotificationService"); // now, the application can add a listener using the EventSource.addListener method. // MyEventType is an interface. MyEventType myListener = ...; AppES.addListener(myListener); // later another component can fire events as follows InitialContext ic = new InitialContext(); EventSource appES = (EventSource) ic.lookup("java:comp/websphere/ApplicationNotificationService"); // This highlights a constant string on the EventSource interface which // specifies the 'java:comp/websphere/ApplicationNotificationService' string. ic.lookup(appES.APPLICATION_NOTIFICATION_EVENT_SOURCE) // now, the application can add a listener using the EventSource.addListener method. MyEventType proxy = appES.getEventTrigger(MyEventType.class, false); proxy.someEvent(someArguments);
Example
Related
Develop event listeners