Class CounterMonitor
- All Implemented Interfaces:
MBeanRegistration, CounterMonitorMBean, MonitorMBean, NotificationBroadcaster, NotificationEmitter
A counter monitor sends a threshold
notification when the value of the counter reaches or exceeds a
threshold known as the comparison level. The notify flag must be
set to true.
In addition, an offset mechanism enables particular counting intervals to be detected. If the offset value is not zero, whenever the threshold is triggered by the counter value reaching a comparison level, that comparison level is incremented by the offset value. This is regarded as taking place instantaneously, that is, before the count is incremented. Thus, for each level, the threshold triggers an event notification every time the count increases by an interval equal to the offset value.
If the counter can wrap around its maximum value, the modulus needs to be specified. The modulus is the value at which the counter is reset to zero.
If the counter difference mode is used, the value of the derived gauge is calculated as the difference between the observed counter values for two successive observations. If this difference is negative, the value of the derived gauge is incremented by the value of the modulus. The derived gauge value (V[t]) is calculated using the following method:
- if (counter[t] - counter[t-GP]) is positive then V[t] = counter[t] - counter[t-GP]
- if (counter[t] - counter[t-GP]) is negative then V[t] = counter[t] - counter[t-GP] + MODULUS
Byte,
Integer, Short, Long).- 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 initial threshold value common to all observed objects.Gets the modulus 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 counter monitor.booleanGets the notification's on/off switch value common to all observed MBeans.Gets the offset value common to all observed MBeans.Deprecated.As of JMX 1.2, replaced bygetThreshold(ObjectName)getThreshold(ObjectName object) Gets the current threshold value of the specified object, if this object is contained in the set of observed MBeans, ornullotherwise.voidsetDifferenceMode(boolean value) Sets the difference mode flag value common to all observed MBeans.voidsetInitThreshold(Number value) Sets the initial threshold value common to all observed objects.voidsetModulus(Number value) Sets the modulus value common to all observed MBeans.voidsetNotify(boolean value) Sets the notification's on/off switch value common to all observed MBeans.voidSets the offset value common to all observed MBeans.voidsetThreshold(Number value) Deprecated.As of JMX 1.2, replaced bysetInitThreshold(Number)voidstart()Starts the counter monitor.voidstop()Stops the counter 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
-
CounterMonitor
public CounterMonitor()Default constructor.
-
-
Method Details
-
start
public void start()Starts the counter monitor.- Specified by:
startin interfaceMonitorMBean- Specified by:
startin classMonitor
-
stop
public void stop()Stops the counter 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 interfaceCounterMonitorMBean- Parameters:
object- the name of the object whose derived gauge is to be returned.- 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 interfaceCounterMonitorMBean- Parameters:
object- the name of the object whose derived gauge timestamp is to be returned.- Returns:
- The derived gauge timestamp of the specified object.
-
getThreshold
Gets the current threshold value of the specified object, if this object is contained in the set of observed MBeans, ornullotherwise.- Specified by:
getThresholdin interfaceCounterMonitorMBean- Parameters:
object- the name of the object whose threshold is to be returned.- Returns:
- The threshold value of the specified object.
- See Also:
-
getInitThreshold
Gets the initial threshold value common to all observed objects.- Specified by:
getInitThresholdin interfaceCounterMonitorMBean- Returns:
- The initial threshold.
- See Also:
-
setInitThreshold
Sets the initial threshold value common to all observed objects.
The current threshold of every object in the set of observed MBeans is updated consequently.- Specified by:
setInitThresholdin interfaceCounterMonitorMBean- Parameters:
value- The initial threshold value.- Throws:
IllegalArgumentException- The specified threshold is null or the threshold value is less than zero.- See Also:
-
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 interfaceCounterMonitorMBean- 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 interfaceCounterMonitorMBean- Returns:
- The derived gauge timestamp.
-
getThreshold
Deprecated.As of JMX 1.2, replaced bygetThreshold(ObjectName)Gets the threshold value of the first object in the set of observed MBeans.- Specified by:
getThresholdin interfaceCounterMonitorMBean- Returns:
- The threshold value.
- See Also:
-
setThreshold
Deprecated.As of JMX 1.2, replaced bysetInitThreshold(Number)Sets the initial threshold value.- Specified by:
setThresholdin interfaceCounterMonitorMBean- Parameters:
value- The initial threshold value.- Throws:
IllegalArgumentException- The specified threshold is null or the threshold value is less than zero.- See Also:
-
getOffset
Gets the offset value common to all observed MBeans.- Specified by:
getOffsetin interfaceCounterMonitorMBean- Returns:
- The offset value.
- See Also:
-
setOffset
Sets the offset value common to all observed MBeans.- Specified by:
setOffsetin interfaceCounterMonitorMBean- Parameters:
value- The offset value.- Throws:
IllegalArgumentException- The specified offset is null or the offset value is less than zero.- See Also:
-
getModulus
Gets the modulus value common to all observed MBeans.- Specified by:
getModulusin interfaceCounterMonitorMBean- Returns:
- The modulus value.
- See Also:
-
setModulus
Sets the modulus value common to all observed MBeans.- Specified by:
setModulusin interfaceCounterMonitorMBean- Parameters:
value- The modulus value.- Throws:
IllegalArgumentException- The specified modulus is null or the modulus value is less than zero.- See Also:
-
getNotify
public boolean getNotify()Gets the notification's on/off switch value common to all observed MBeans.- Specified by:
getNotifyin interfaceCounterMonitorMBean- Returns:
trueif the counter monitor notifies when exceeding the threshold,falseotherwise.- See Also:
-
setNotify
public void setNotify(boolean value) Sets the notification's on/off switch value common to all observed MBeans.- Specified by:
setNotifyin interfaceCounterMonitorMBean- Parameters:
value- The 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 interfaceCounterMonitorMBean- 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 interfaceCounterMonitorMBean- 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 counter monitor.- Specified by:
getNotificationInfoin interfaceNotificationBroadcaster- Returns:
- the array of possible notifications.
-
Monitor.alreadyNotifieds[0].