Event queues
When an event occurs, the queue manager puts an event message on the defined event queue. The event message contains information about the event.
We can define event queues, either as:If you define all your event queues as local definitions of the same remote queue on one queue manager, we can centralize your monitoring activities.
- Local queues
- Alias queues
- Local definitions of remote queues, or as
- Remote cluster queues
You must not define event queues as transmission queues, because event messages have formats that are incompatible with the message format that is required for transmission queues.
Shared event queues are local queues defined with the QSGDISP(SHARED) value.
For more information about defining shared queues on z/OSĀ®, see Application programming with shared queues.
When an event queue is unavailable
If an event occurs when the event queue is not available, the event message is lost. For example, if we do not define an event queue for a category of event, all event messages for that category are lost. The event messages are not, for example, saved on the dead-letter (undelivered-message) queue.
However, we can define the event queue as a remote queue. Then, if there is a problem on the remote system putting messages to the resolved queue, the event message arrives on the dead-letter queue of the remote system.
An event queue might be unavailable for many different reasons including:
- The queue has not been defined.
- The queue has been deleted.
- The queue is full.
- The queue has been put-inhibited.
The absence of an event queue does not prevent the event from occurring. For example, after a performance event, the queue manager changes the queue attributes and resets the queue statistics. This change happens whether the event message is put on the performance event queue or not. The same is true in the case of configuration and command events.
Use triggered event queues
We can set up the event queues with triggers so that when an event is generated, the event message being put onto the event queue starts a user-written monitoring application. This application can process the event messages and take appropriate action. For example, certain events might require an operator to be informed, other events might start an application that performs some administration tasks automatically.
Event queues can have trigger actions associated with them and can create trigger messages. However, if these trigger messages in turn cause conditions that would normally generate an event, no event is generated. not generating an event in this instance ensures that looping does not occur.