Class CounterMonitor
- All Implemented Interfaces:
-
MBeanRegistration,CounterMonitorMBean,MonitorMBean,NotificationBroadcaster,NotificationEmitter
public class CounterMonitor extends Monitor implements CounterMonitorMBean
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 javax.management.monitor.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
Constructor Summary
| Constructor | Description |
|---|---|
CounterMonitor() |
Default constructor. |
Method Summary
| Modifier and Type | Method | Description |
|---|---|---|
Number |
getDerivedGauge() |
Deprecated. |
Number |
getDerivedGauge |
Gets the derived gauge of the specified object, if this object is contained in the set of observed MBeans, or null otherwise. |
long |
getDerivedGaugeTimeStamp() |
Deprecated. As of JMX 1.2, replaced by getDerivedGaugeTimeStamp(ObjectName)
|
long |
getDerivedGaugeTimeStamp |
Gets the derived gauge timestamp of the specified object, if this object is contained in the set of observed MBeans, or 0 otherwise. |
boolean |
getDifferenceMode() |
Gets the difference mode flag value common to all observed MBeans. |
Number |
getInitThreshold() |
Gets the initial threshold value common to all observed objects. |
Number |
getModulus() |
Gets the modulus value common to all observed MBeans. |
MBeanNotificationInfo[] |
getNotificationInfo() |
Returns a NotificationInfo object containing the name of the Java class of the notification and the notification types sent by the counter monitor. |
boolean |
getNotify() |
Gets the notification's on/off switch value common to all observed MBeans. |
Number |
getOffset() |
Gets the offset value common to all observed MBeans. |
Number |
getThreshold() |
Deprecated. As of JMX 1.2, replaced by getThreshold(ObjectName)
|
Number |
getThreshold |
Gets the current threshold value of the specified object, if this object is contained in the set of observed MBeans, or null otherwise. |
void |
setDifferenceMode |
Sets the difference mode flag value common to all observed MBeans. |
void |
setInitThreshold |
Sets the initial threshold value common to all observed objects. |
void |
setModulus |
Sets the modulus value common to all observed MBeans. |
void |
setNotify |
Sets the notification's on/off switch value common to all observed MBeans. |
void |
setOffset |
Sets the offset value common to all observed MBeans. |
void |
setThreshold |
Deprecated. As of JMX 1.2, replaced by setInitThreshold(java.lang.Number)
|
void |
start() |
Starts the counter monitor. |
void |
stop() |
Stops the counter monitor. |
Methods declared in class javax.management.monitor.Monitor
addObservedObject, containsObservedObject, getGranularityPeriod, getObservedAttribute, getObservedObject, getObservedObjects, isActive, postDeregister, postRegister, preDeregister, preRegister, removeObservedObject, setGranularityPeriod, setObservedAttribute, setObservedObject
Methods declared in class javax.management.NotificationBroadcasterSupport
addNotificationListener, handleNotification, removeNotificationListener, removeNotificationListener, sendNotification
Methods declared in class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods declared in interface javax.management.monitor.MonitorMBean
addObservedObject, containsObservedObject, getGranularityPeriod, getObservedAttribute, getObservedObject, getObservedObjects, isActive, removeObservedObject, setGranularityPeriod, setObservedAttribute, setObservedObject
Constructor Details
CounterMonitor
public CounterMonitor()
Method Details
start
public void start()
- Specified by:
-
startin interfaceMonitorMBean - Specified by:
-
startin classMonitor
stop
public void stop()
- Specified by:
-
stopin interfaceMonitorMBean - Specified by:
-
stopin classMonitor
getDerivedGauge
public Number getDerivedGauge(ObjectName object)
null otherwise.- 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
public long getDerivedGaugeTimeStamp(ObjectName object)
0 otherwise.- 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
public Number getThreshold(ObjectName object)
null otherwise.- 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
public Number getInitThreshold()
- Specified by:
-
getInitThresholdin interfaceCounterMonitorMBean - Returns:
- The initial threshold.
- See Also:
setInitThreshold
public void setInitThreshold(Number value) throws IllegalArgumentException
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 public Number getDerivedGauge()
getDerivedGauge(ObjectName)
- Specified by:
-
getDerivedGaugein interfaceCounterMonitorMBean - Returns:
- The derived gauge.
getDerivedGaugeTimeStamp
@Deprecated public long getDerivedGaugeTimeStamp()
getDerivedGaugeTimeStamp(ObjectName)
- Specified by:
-
getDerivedGaugeTimeStampin interfaceCounterMonitorMBean - Returns:
- The derived gauge timestamp.
getThreshold
@Deprecated public Number getThreshold()
getThreshold(ObjectName)
- Specified by:
-
getThresholdin interfaceCounterMonitorMBean - Returns:
- The threshold value.
- See Also:
setThreshold
@Deprecated public void setThreshold(Number value) throws IllegalArgumentException
setInitThreshold(java.lang.Number)
- 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
public Number getOffset()
- Specified by:
-
getOffsetin interfaceCounterMonitorMBean - Returns:
- The offset value.
- See Also:
setOffset
public void setOffset(Number value) throws IllegalArgumentException
- 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
public Number getModulus()
- Specified by:
-
getModulusin interfaceCounterMonitorMBean - Returns:
- The modulus value.
- See Also:
setModulus
public void setModulus(Number value) throws IllegalArgumentException
- 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()
- Specified by:
-
getNotifyin interfaceCounterMonitorMBean - Returns:
-
trueif the counter monitor notifies when exceeding the threshold,falseotherwise. - See Also:
setNotify
public void setNotify(boolean value)
- Specified by:
-
setNotifyin interfaceCounterMonitorMBean - Parameters:
-
value- The notification's on/off switch value. - See Also:
getDifferenceMode
public boolean getDifferenceMode()
- Specified by:
-
getDifferenceModein interfaceCounterMonitorMBean - Returns:
-
trueif the difference mode is used,falseotherwise. - See Also:
setDifferenceMode
public void setDifferenceMode(boolean value)
- Specified by:
-
setDifferenceModein interfaceCounterMonitorMBean - Parameters:
-
value- The difference mode flag value. - See Also:
getNotificationInfo
public MBeanNotificationInfo[] getNotificationInfo()
NotificationInfo object 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.
© 1993, 2021, Oracle and/or its affiliates. All rights reserved.
Documentation extracted from Debian's OpenJDK Development Kit package.
Licensed under the GNU General Public License, version 2, with the Classpath Exception.
Various third party code in OpenJDK is licensed under different licenses (see Debian package).
Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.
https://docs.oracle.com/en/java/javase/17/docs/api/java.management/javax/management/monitor/CounterMonitor.html
getDerivedGauge(ObjectName)