Class GaugeMonitor
java.lang.Object
javax.management.NotificationBroadcasterSupport
javax.management.monitor.Monitor
javax.management.monitor.GaugeMonitor
- All Implemented Interfaces:
MBeanRegistration, GaugeMonitorMBean, MonitorMBean, NotificationBroadcaster, NotificationEmitter
Defines a monitor MBean designed to observe the values of a gauge attribute.
A gauge monitor observes an attribute that is continuously variable with time. A gauge monitor sends notifications as follows:
- if the attribute value is increasing and becomes equal to or
greater than the high threshold value, a
threshold high notificationis sent. The notify high flag must be set totrue.
Subsequent crossings of the high threshold value do not cause further notifications unless the attribute value becomes equal to or less than the low threshold value. - if the attribute value is decreasing and becomes equal to or
less than the low threshold value, a
threshold low notificationis sent. The notify low flag must be set totrue.
Subsequent crossings of the low threshold value do not cause further notifications unless the attribute value becomes equal to or greater than the high threshold value.
If the gauge difference mode is used, the value of the derived
gauge is calculated as the difference between the observed gauge
values for two successive observations.
The derived gauge value (V[t]) is calculated using the following method:
- V[t] = gauge[t] - gauge[t-GP]
Byte, Integer, Short,
Long, Float, Double).- Since:
- 1.5
-
Field Summary
Fields declared in class Monitor
alreadyNotified, alreadyNotifieds, capacityIncrement, dbgTag, elementCount, OBSERVED_ATTRIBUTE_ERROR_NOTIFIED, OBSERVED_ATTRIBUTE_TYPE_ERROR_NOTIFIED, OBSERVED_OBJECT_ERROR_NOTIFIED, RESET_FLAGS_ALREADY_NOTIFIED, RUNTIME_ERROR_NOTIFIED, serverModifier and TypeFieldDescriptionprotected intDeprecated.protected int[]Selected monitor errors that have already been notified.protected static final intThe amount by which the capacity of the monitor arrays are automatically incremented when their size becomes greater than their capacity.protected StringDeprecated.No replacement.protected intThe number of valid components in the vector of observed objects.protected static final intFlag denoting that a notification has occurred after changing the observed attribute.protected static final intFlag denoting that a notification has occurred after changing the observed object or the observed attribute.protected static final intFlag denoting that a notification has occurred after changing the observed object.protected static final intThis flag is used to reset thealreadyNotifiedsmonitor attribute.protected static final intFlag denoting that a notification has occurred after changing the observed object or the observed attribute.protected MBeanServerReference to the MBean server. -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionDeprecated.As of JMX 1.2, replaced bygetDerivedGauge(ObjectName)getDerivedGauge(ObjectName object) Gets the derived gauge of the specified object, if this object is contained in the set of observed MBeans, ornullotherwise.longDeprecated.As of JMX 1.2, replaced bygetDerivedGaugeTimeStamp(ObjectName)longgetDerivedGaugeTimeStamp(ObjectName object) Gets the derived gauge timestamp of the specified object, if this object is contained in the set of observed MBeans, or0otherwise.booleanGets the difference mode flag value common to all observed MBeans.Gets the high threshold value common to all observed MBeans.Gets the low threshold value common to all observed MBeans.Returns aNotificationInfoobject containing the name of the Java class of the notification and the notification types sent by the gauge monitor.booleanGets the high notification's on/off switch value common to all observed MBeans.booleanGets the low notification's on/off switch value common to all observed MBeans.voidsetDifferenceMode(boolean value) Sets the difference mode flag value common to all observed MBeans.voidsetNotifyHigh(boolean value) Sets the high notification's on/off switch value common to all observed MBeans.voidsetNotifyLow(boolean value) Sets the low notification's on/off switch value common to all observed MBeans.voidsetThresholds(Number highValue, Number lowValue) Sets the high and the low threshold values common to all observed MBeans.voidstart()Starts the gauge monitor.voidstop()Stops the gauge monitor.Methods declared in class Monitor
addObservedObject, containsObservedObject, getGranularityPeriod, getObservedAttribute, getObservedObject, getObservedObjects, isActive, postDeregister, postRegister, preDeregister, preRegister, removeObservedObject, setGranularityPeriod, setObservedAttribute, setObservedObjectModifier and TypeMethodDescriptionvoidaddObservedObject(ObjectName object) Adds the specified object in the set of observed MBeans, if this object is not already present.booleancontainsObservedObject(ObjectName object) Tests whether the specified object is in the set of observed MBeans.longGets the granularity period (in milliseconds).Gets the attribute being observed.Deprecated.As of JMX 1.2, replaced byMonitor.getObservedObjects()Returns an array containing the objects being observed.booleanisActive()Tests whether the monitor MBean is active.voidAllows the monitor MBean to perform any operations needed after having been unregistered by the MBean server.voidpostRegister(Boolean registrationDone) Allows the monitor MBean to perform any operations needed after having been registered in the MBean server or after the registration has failed.voidAllows the monitor MBean to perform any operations it needs before being unregistered by the MBean server.preRegister(MBeanServer server, ObjectName name) Allows the monitor MBean to perform any operations it needs before being registered in the MBean server.voidremoveObservedObject(ObjectName object) Removes the specified object from the set of observed MBeans.voidsetGranularityPeriod(long period) Sets the granularity period (in milliseconds).voidsetObservedAttribute(String attribute) Sets the attribute to observe.voidsetObservedObject(ObjectName object) Deprecated.As of JMX 1.2, replaced byMonitor.addObservedObject(ObjectName)Methods declared in class NotificationBroadcasterSupport
addNotificationListener, handleNotification, removeNotificationListener, removeNotificationListener, sendNotificationModifier and TypeMethodDescriptionvoidaddNotificationListener(NotificationListener listener, NotificationFilter filter, Object handback) Adds a listener.protected voidhandleNotification(NotificationListener listener, Notification notif, Object handback) This method is called bysendNotificationfor each listener in order to send the notification to that listener.voidRemoves a listener from this MBean.voidremoveNotificationListener(NotificationListener listener, NotificationFilter filter, Object handback) Removes a listener from this MBean.voidsendNotification(Notification notification) Sends a notification.Methods declared in class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitModifier and TypeMethodDescriptionprotected Objectclone()Creates and returns a copy of this object.booleanIndicates whether some other object is "equal to" this one.protected voidfinalize()Deprecated, for removal: This API element is subject to removal in a future version.Finalization is deprecated and subject to removal in a future release.final Class<?> getClass()Returns the runtime class of thisObject.inthashCode()Returns a hash code value for this object.final voidnotify()Wakes up a single thread that is waiting on this object's monitor.final voidWakes up all threads that are waiting on this object's monitor.toString()Returns a string representation of the object.final voidwait()Causes the current thread to wait until it is awakened, typically by being notified or interrupted.final voidwait(long timeoutMillis) Causes the current thread to wait until it is awakened, typically by being notified or interrupted, or until a certain amount of real time has elapsed.final voidwait(long timeoutMillis, int nanos) Causes the current thread to wait until it is awakened, typically by being notified or interrupted, or until a certain amount of real time has elapsed.
-
Constructor Details
-
GaugeMonitor
public GaugeMonitor()Default constructor.
-
-
Method Details
-
start
public void start()Starts the gauge monitor.- Specified by:
startin interfaceMonitorMBean- Specified by:
startin classMonitor
-
stop
public void stop()Stops the gauge monitor.- Specified by:
stopin interfaceMonitorMBean- Specified by:
stopin classMonitor
-
getDerivedGauge
Gets the derived gauge of the specified object, if this object is contained in the set of observed MBeans, ornullotherwise.- Specified by:
getDerivedGaugein interfaceGaugeMonitorMBean- Parameters:
object- the name of the MBean.- Returns:
- The derived gauge of the specified object.
-
getDerivedGaugeTimeStamp
Gets the derived gauge timestamp of the specified object, if this object is contained in the set of observed MBeans, or0otherwise.- Specified by:
getDerivedGaugeTimeStampin interfaceGaugeMonitorMBean- Parameters:
object- the name of the object whose derived gauge timestamp is to be returned.- Returns:
- The derived gauge timestamp of the specified object.
-
getDerivedGauge
Deprecated.As of JMX 1.2, replaced bygetDerivedGauge(ObjectName)Returns the derived gauge of the first object in the set of observed MBeans.- Specified by:
getDerivedGaugein interfaceGaugeMonitorMBean- Returns:
- The derived gauge.
-
getDerivedGaugeTimeStamp
Deprecated.As of JMX 1.2, replaced bygetDerivedGaugeTimeStamp(ObjectName)Gets the derived gauge timestamp of the first object in the set of observed MBeans.- Specified by:
getDerivedGaugeTimeStampin interfaceGaugeMonitorMBean- Returns:
- The derived gauge timestamp.
-
getHighThreshold
Gets the high threshold value common to all observed MBeans.- Specified by:
getHighThresholdin interfaceGaugeMonitorMBean- Returns:
- The high threshold value.
- See Also:
-
getLowThreshold
Gets the low threshold value common to all observed MBeans.- Specified by:
getLowThresholdin interfaceGaugeMonitorMBean- Returns:
- The low threshold value.
- See Also:
-
setThresholds
Sets the high and the low threshold values common to all observed MBeans.- Specified by:
setThresholdsin interfaceGaugeMonitorMBean- Parameters:
highValue- The high threshold value.lowValue- The low threshold value.- Throws:
IllegalArgumentException- The specified high/low threshold is null or the low threshold is greater than the high threshold or the high threshold and the low threshold are not of the same type.- See Also:
-
getNotifyHigh
public boolean getNotifyHigh()Gets the high notification's on/off switch value common to all observed MBeans.- Specified by:
getNotifyHighin interfaceGaugeMonitorMBean- Returns:
trueif the gauge monitor notifies when exceeding the high threshold,falseotherwise.- See Also:
-
setNotifyHigh
public void setNotifyHigh(boolean value) Sets the high notification's on/off switch value common to all observed MBeans.- Specified by:
setNotifyHighin interfaceGaugeMonitorMBean- Parameters:
value- The high notification's on/off switch value.- See Also:
-
getNotifyLow
public boolean getNotifyLow()Gets the low notification's on/off switch value common to all observed MBeans.- Specified by:
getNotifyLowin interfaceGaugeMonitorMBean- Returns:
trueif the gauge monitor notifies when exceeding the low threshold,falseotherwise.- See Also:
-
setNotifyLow
public void setNotifyLow(boolean value) Sets the low notification's on/off switch value common to all observed MBeans.- Specified by:
setNotifyLowin interfaceGaugeMonitorMBean- Parameters:
value- The low notification's on/off switch value.- See Also:
-
getDifferenceMode
public boolean getDifferenceMode()Gets the difference mode flag value common to all observed MBeans.- Specified by:
getDifferenceModein interfaceGaugeMonitorMBean- Returns:
trueif the difference mode is used,falseotherwise.- See Also:
-
setDifferenceMode
public void setDifferenceMode(boolean value) Sets the difference mode flag value common to all observed MBeans.- Specified by:
setDifferenceModein interfaceGaugeMonitorMBean- Parameters:
value- The difference mode flag value.- See Also:
-
getNotificationInfo
Returns aNotificationInfoobject containing the name of the Java class of the notification and the notification types sent by the gauge monitor.- Specified by:
getNotificationInfoin interfaceNotificationBroadcaster- Returns:
- the array of possible notifications.
-
Monitor.alreadyNotifieds[0].