To receive MBeanServerNotifications, you need to register a listener with
the MBeanServerDelegate
MBean
that represents the MBeanServer. The ObjectName of the MBeanServerDelegate is
MBeanServerDelegate#DELEGATE_NAME
, which is
JMImplementation:type=MBeanServerDelegate
.
The following code prints a message every time an MBean is registered
or unregistered in the MBean Server mbeanServer
:
private static final NotificationListener printListener = new NotificationListener() { public void handleNotification(Notification n, Object handback) { if (!(n instanceof MBeanServerNotification)) { System.out.println("Ignored notification of class " + n.getClass().getName()); return; } MBeanServerNotification mbsn = (MBeanServerNotification) n; String what; if (n.getType().equals(MBeanServerNotification.REGISTRATION_NOTIFICATION)) what = "MBean registered"; else if (n.getType().equals(MBeanServerNotification.UNREGISTRATION_NOTIFICATION)) what = "MBean unregistered"; else what = "Unknown type " + n.getType(); System.out.println("Received MBean Server notification: " + what + ": " + mbsn.getMBeanName()); } }; ... mbeanServer.addNotificationListener( MBeanServerDelegate.DELEGATE_NAME, printListener, null, null);
An MBean which is not an MBeanServerDelegate
may also emit
MBeanServerNotifications. In particular, there is a convention for
MBeans to emit an MBeanServerNotification for a group of MBeans.
An MBeanServerNotification emitted to denote the registration or unregistration of a group of MBeans has the following characteristics:
"JMX.mbean.registered.group"
or
"JMX.mbean.unregistered.group"
, which can also be written MBeanServerNotification#REGISTRATION_NOTIFICATION
+ ".group"
or
MBeanServerNotification#UNREGISTRATION_NOTIFICATION
+ ".group"
.
MBeans which emit these group registration/unregistration notifications will
declare them in their MBeanNotificationInfo
.
Modifier and Type | Field and Description |
---|---|
private final ObjectName | |
public static final String | REGISTRATION_NOTIFICATION
Notification type denoting that an MBean has been registered. |
private static final long | |
public static final String | UNREGISTRATION_NOTIFICATION
Notification type denoting that an MBean has been unregistered. |
Access | Constructor and Description |
---|---|
public | MBeanServerNotification(String
A string denoting the type of the
notification. Set it to one these values: type, Object REGISTRATION_NOTIFICATION , UNREGISTRATION_NOTIFICATION .The MBeanServerNotification object responsible
for forwarding MBean server notification. source, long A sequence number that can be used to order
received notifications. sequenceNumber, ObjectName The object name of the MBean that caused the
notification. objectName)Creates an MBeanServerNotification object specifying object names of the MBeans that caused the notification and the specified notification type. |
Modifier and Type | Method and Description |
---|---|
public ObjectName | Returns: the object name of the MBean that caused the notification.Returns the object name of the MBean that caused the notification. |
public String | toString()
Overrides javax. |
objectName | back to summary |
---|---|
private final ObjectName objectName |
REGISTRATION_NOTIFICATION | back to summary |
---|---|
public static final String REGISTRATION_NOTIFICATION Notification type denoting that an MBean has been registered. Value is "JMX.mbean.registered". |
serialVersionUID | back to summary |
---|---|
private static final long serialVersionUID |
UNREGISTRATION_NOTIFICATION | back to summary |
---|---|
public static final String UNREGISTRATION_NOTIFICATION Notification type denoting that an MBean has been unregistered. Value is "JMX.mbean.unregistered". |
MBeanServerNotification | back to summary |
---|---|
public MBeanServerNotification(String type, Object source, long sequenceNumber, ObjectName objectName) Creates an MBeanServerNotification object specifying object names of the MBeans that caused the notification and the specified notification type.
|
getMBeanName | back to summary |
---|---|
public ObjectName getMBeanName() Returns the object name of the MBean that caused the notification.
|
toString | back to summary |
---|---|
public String toString() Overrides javax. Doc from javax. Returns a String representation of this notification. |