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 notification
is 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 notification
is 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, server
Modifier and TypeFieldDescriptionprotected int
Deprecated.protected int[]
Selected monitor errors that have already been notified.protected static final int
The amount by which the capacity of the monitor arrays are automatically incremented when their size becomes greater than their capacity.protected String
Deprecated.No replacement.protected int
The number of valid components in the vector of observed objects.protected static final int
Flag denoting that a notification has occurred after changing the observed attribute.protected static final int
Flag denoting that a notification has occurred after changing the observed object or the observed attribute.protected static final int
Flag denoting that a notification has occurred after changing the observed object.protected static final int
This flag is used to reset thealreadyNotifieds
monitor attribute.protected static final int
Flag denoting that a notification has occurred after changing the observed object or the observed attribute.protected MBeanServer
Reference 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, ornull
otherwise.long
Deprecated.As of JMX 1.2, replaced bygetDerivedGaugeTimeStamp(ObjectName)
long
getDerivedGaugeTimeStamp
(ObjectName object) Gets the derived gauge timestamp of the specified object, if this object is contained in the set of observed MBeans, or0
otherwise.boolean
Gets 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 aNotificationInfo
object containing the name of the Java class of the notification and the notification types sent by the gauge monitor.boolean
Gets the high notification's on/off switch value common to all observed MBeans.boolean
Gets the low notification's on/off switch value common to all observed MBeans.void
setDifferenceMode
(boolean value) Sets the difference mode flag value common to all observed MBeans.void
setNotifyHigh
(boolean value) Sets the high notification's on/off switch value common to all observed MBeans.void
setNotifyLow
(boolean value) Sets the low notification's on/off switch value common to all observed MBeans.void
setThresholds
(Number highValue, Number lowValue) Sets the high and the low threshold values common to all observed MBeans.void
start()
Starts the gauge monitor.void
stop()
Stops the gauge monitor.Methods declared in class Monitor
addObservedObject, containsObservedObject, getGranularityPeriod, getObservedAttribute, getObservedObject, getObservedObjects, isActive, postDeregister, postRegister, preDeregister, preRegister, removeObservedObject, setGranularityPeriod, setObservedAttribute, setObservedObject
Modifier and TypeMethodDescriptionvoid
addObservedObject
(ObjectName object) Adds the specified object in the set of observed MBeans, if this object is not already present.boolean
containsObservedObject
(ObjectName object) Tests whether the specified object is in the set of observed MBeans.long
Gets 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.boolean
isActive()
Tests whether the monitor MBean is active.void
Allows the monitor MBean to perform any operations needed after having been unregistered by the MBean server.void
postRegister
(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.void
Allows 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.void
removeObservedObject
(ObjectName object) Removes the specified object from the set of observed MBeans.void
setGranularityPeriod
(long period) Sets the granularity period (in milliseconds).void
setObservedAttribute
(String attribute) Sets the attribute to observe.void
setObservedObject
(ObjectName object) Deprecated.As of JMX 1.2, replaced byMonitor.addObservedObject(ObjectName)
Methods declared in class NotificationBroadcasterSupport
addNotificationListener, handleNotification, removeNotificationListener, removeNotificationListener, sendNotification
Modifier and TypeMethodDescriptionvoid
addNotificationListener
(NotificationListener listener, NotificationFilter filter, Object handback) Adds a listener.protected void
handleNotification
(NotificationListener listener, Notification notif, Object handback) This method is called bysendNotification
for each listener in order to send the notification to that listener.void
Removes a listener from this MBean.void
removeNotificationListener
(NotificationListener listener, NotificationFilter filter, Object handback) Removes a listener from this MBean.void
sendNotification
(Notification notification) Sends a notification.Methods declared in class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Modifier and TypeMethodDescriptionprotected Object
clone()
Creates and returns a copy of this object.boolean
Indicates whether some other object is "equal to" this one.protected void
finalize()
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
.int
hashCode()
Returns a hash code value for this object.final void
notify()
Wakes up a single thread that is waiting on this object's monitor.final void
Wakes up all threads that are waiting on this object's monitor.toString()
Returns a string representation of the object.final void
wait()
Causes the current thread to wait until it is awakened, typically by being notified or interrupted.final void
wait
(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 void
wait
(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:
start
in interfaceMonitorMBean
- Specified by:
start
in classMonitor
-
stop
public void stop()Stops the gauge monitor.- Specified by:
stop
in interfaceMonitorMBean
- Specified by:
stop
in classMonitor
-
getDerivedGauge
Gets the derived gauge of the specified object, if this object is contained in the set of observed MBeans, ornull
otherwise.- Specified by:
getDerivedGauge
in 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, or0
otherwise.- Specified by:
getDerivedGaugeTimeStamp
in 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:
getDerivedGauge
in 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:
getDerivedGaugeTimeStamp
in interfaceGaugeMonitorMBean
- Returns:
- The derived gauge timestamp.
-
getHighThreshold
Gets the high threshold value common to all observed MBeans.- Specified by:
getHighThreshold
in interfaceGaugeMonitorMBean
- Returns:
- The high threshold value.
- See Also:
-
getLowThreshold
Gets the low threshold value common to all observed MBeans.- Specified by:
getLowThreshold
in interfaceGaugeMonitorMBean
- Returns:
- The low threshold value.
- See Also:
-
setThresholds
Sets the high and the low threshold values common to all observed MBeans.- Specified by:
setThresholds
in 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:
getNotifyHigh
in interfaceGaugeMonitorMBean
- Returns:
true
if the gauge monitor notifies when exceeding the high threshold,false
otherwise.- See Also:
-
setNotifyHigh
public void setNotifyHigh(boolean value) Sets the high notification's on/off switch value common to all observed MBeans.- Specified by:
setNotifyHigh
in 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:
getNotifyLow
in interfaceGaugeMonitorMBean
- Returns:
true
if the gauge monitor notifies when exceeding the low threshold,false
otherwise.- See Also:
-
setNotifyLow
public void setNotifyLow(boolean value) Sets the low notification's on/off switch value common to all observed MBeans.- Specified by:
setNotifyLow
in 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:
getDifferenceMode
in interfaceGaugeMonitorMBean
- Returns:
true
if the difference mode is used,false
otherwise.- See Also:
-
setDifferenceMode
public void setDifferenceMode(boolean value) Sets the difference mode flag value common to all observed MBeans.- Specified by:
setDifferenceMode
in interfaceGaugeMonitorMBean
- Parameters:
value
- The difference mode flag value.- See Also:
-
getNotificationInfo
Returns aNotificationInfo
object containing the name of the Java class of the notification and the notification types sent by the gauge monitor.- Specified by:
getNotificationInfo
in interfaceNotificationBroadcaster
- Returns:
- the array of possible notifications.
-
Monitor.alreadyNotifieds
[0].