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:
Byte,
 Integer, Short, Long).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 and Description | 
|---|
| CounterMonitor()Default constructor. | 
| Modifier and Type | Method and Description | 
|---|---|
| Number | getDerivedGauge()Deprecated. 
 As of JMX 1.2, replaced by
  getDerivedGauge(ObjectName) | 
| Number | getDerivedGauge(ObjectName object)Gets the derived gauge of the specified object, if this object is
 contained in the set of observed MBeans, or  nullotherwise. | 
| long | getDerivedGaugeTimeStamp()Deprecated. 
 As of JMX 1.2, replaced by
  getDerivedGaugeTimeStamp(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, or
  0otherwise. | 
| 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  NotificationInfoobject 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(ObjectName object)Gets the current threshold value of the specified object, if
 this object is contained in the set of observed MBeans, or
  nullotherwise. | 
| void | setDifferenceMode(boolean value)Sets the difference mode flag value common to all observed MBeans. | 
| void | setInitThreshold(Number value)Sets the initial threshold value common to all observed objects. | 
| void | setModulus(Number value)Sets the modulus value common to all observed MBeans. | 
| void | setNotify(boolean value)Sets the notification's on/off switch value common to all
 observed MBeans. | 
| void | setOffset(Number value)Sets the offset value common to all observed MBeans. | 
| void | setThreshold(Number value)Deprecated. 
 As of JMX 1.2, replaced by  setInitThreshold(java.lang.Number) | 
| void | start()Starts the counter monitor. | 
| void | stop()Stops the counter monitor. | 
addObservedObject, containsObservedObject, getGranularityPeriod, getObservedAttribute, getObservedObject, getObservedObjects, isActive, postDeregister, postRegister, preDeregister, preRegister, removeObservedObject, setGranularityPeriod, setObservedAttribute, setObservedObjectaddNotificationListener, handleNotification, removeNotificationListener, removeNotificationListener, sendNotificationclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitaddObservedObject, containsObservedObject, getGranularityPeriod, getObservedAttribute, getObservedObject, getObservedObjects, isActive, removeObservedObject, setGranularityPeriod, setObservedAttribute, setObservedObjectpublic void start()
start in interface MonitorMBeanstart in class Monitorpublic void stop()
stop in interface MonitorMBeanstop in class Monitorpublic Number getDerivedGauge(ObjectName object)
null otherwise.getDerivedGauge in interface CounterMonitorMBeanobject - the name of the object whose derived gauge is to
 be returned.public long getDerivedGaugeTimeStamp(ObjectName object)
0 otherwise.getDerivedGaugeTimeStamp in interface CounterMonitorMBeanobject - the name of the object whose derived gauge
 timestamp is to be returned.public Number getThreshold(ObjectName object)
null otherwise.getThreshold in interface CounterMonitorMBeanobject - the name of the object whose threshold is to be
 returned.CounterMonitorMBean.setThreshold(java.lang.Number)public Number getInitThreshold()
getInitThreshold in interface CounterMonitorMBeansetInitThreshold(java.lang.Number)public void setInitThreshold(Number value) throws IllegalArgumentException
setInitThreshold in interface CounterMonitorMBeanvalue - The initial threshold value.IllegalArgumentException - The specified
 threshold is null or the threshold value is less than zero.getInitThreshold()@Deprecated public Number getDerivedGauge()
getDerivedGauge(ObjectName)getDerivedGauge in interface CounterMonitorMBean@Deprecated public long getDerivedGaugeTimeStamp()
getDerivedGaugeTimeStamp(ObjectName)getDerivedGaugeTimeStamp in interface CounterMonitorMBean@Deprecated public Number getThreshold()
getThreshold(ObjectName)getThreshold in interface CounterMonitorMBeansetThreshold(java.lang.Number)@Deprecated public void setThreshold(Number value) throws IllegalArgumentException
setInitThreshold(java.lang.Number)setThreshold in interface CounterMonitorMBeanvalue - The initial threshold value.IllegalArgumentException - The specified threshold is
 null or the threshold value is less than zero.getThreshold()public Number getOffset()
getOffset in interface CounterMonitorMBeansetOffset(java.lang.Number)public void setOffset(Number value) throws IllegalArgumentException
setOffset in interface CounterMonitorMBeanvalue - The offset value.IllegalArgumentException - The specified
 offset is null or the offset value is less than zero.getOffset()public Number getModulus()
getModulus in interface CounterMonitorMBeansetModulus(java.lang.Number)public void setModulus(Number value) throws IllegalArgumentException
setModulus in interface CounterMonitorMBeanvalue - The modulus value.IllegalArgumentException - The specified
 modulus is null or the modulus value is less than zero.getModulus()public boolean getNotify()
getNotify in interface CounterMonitorMBeantrue if the counter monitor notifies when
 exceeding the threshold, false otherwise.setNotify(boolean)public void setNotify(boolean value)
setNotify in interface CounterMonitorMBeanvalue - The notification's on/off switch value.getNotify()public boolean getDifferenceMode()
getDifferenceMode in interface CounterMonitorMBeantrue if the difference mode is used,
 false otherwise.setDifferenceMode(boolean)public void setDifferenceMode(boolean value)
setDifferenceMode in interface CounterMonitorMBeanvalue - The difference mode flag value.getDifferenceMode()public MBeanNotificationInfo[] getNotificationInfo()
NotificationInfo object containing the
 name of the Java class of the notification and the notification
 types sent by the counter monitor.getNotificationInfo in interface NotificationBroadcastergetNotificationInfo in class NotificationBroadcasterSupport Submit a bug or feature 
For further API reference and developer documentation, see Java SE Documentation. That documentation contains more detailed, developer-targeted descriptions, with conceptual overviews, definitions of terms, workarounds, and working code examples.
 Copyright © 1993, 2018, Oracle and/or its affiliates.  All rights reserved. Use is subject to license terms. Also see the documentation redistribution policy.