All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.javasimon.jmx.SimonManagerMXBean Maven / Gradle / Ivy

package org.javasimon.jmx;

import org.javasimon.StopwatchSample;

import java.io.Serializable;
import java.util.List;

/**
 * Interface of Simon management bean (MXBean) representing single point of access to a particular Simon
 * {@link org.javasimon.Manager}.
 * 

* It provides general management tasks over all Simons for a single Manager (hierarchy of Simons) * plus some useful util functions. * * @author Radovan Sninsky * @since 2.0 */ @SuppressWarnings("UnusedDeclaration") public interface SimonManagerMXBean extends Serializable { /** * Enables the Simon Manager, enable monitoring application by Simons. * * @see org.javasimon.Manager#enable() */ void enable(); /** * Disables the Simon Manager, disable monitoring application by Simons. * * @see org.javasimon.Manager#disable() */ void disable(); /** * Returns true if the Simon Manager is enabled, if monitoring is enabled. * * @return true if the Simon Manager is enabled * @see org.javasimon.Manager#isEnabled() */ boolean isEnabled(); /** * Returns array containing full hierarchical names of all existing Simons. * * @return array of all Simon names * @see org.javasimon.Manager#getSimonNames() */ String[] getSimonNames(); /** * Returns array containing full hierarchical names of all existing Simons in natural String order. * * @return array of all Simon names (ordered) * @see org.javasimon.Manager#getSimonNames() */ String[] getSimonNamesOrdered(); /** * Returns type of Simon, either COUNTER, STOPWATCH or UNKNOWN. * * @param name name of Simon * @return string COUNTER if Counter Simon, STOPWATCH if Stopwatch Simon * or UNKNOWN if there is no Simon just undefined hierarchy node */ String getType(String name); /** * Returns array containing names and types of all existing Simons ordered naturally by name. * * @return array of {@link SimonInfo} objects */ SimonInfo[] getSimonInfos(); /** * Clears the Manager (ignored if manager is disabled). All Simons are lost, * but the configuration is preserved. * * @see org.javasimon.Manager#clear() */ void clearManager(); /** * Enables particular Simon only. * * @param name name of the Simon * @see org.javasimon.Simon#setState(org.javasimon.SimonState, boolean) */ void enableSimon(String name); /** * Disables particular Simon only. * * @param name name of the Simon * @see org.javasimon.Simon#setState(org.javasimon.SimonState, boolean) */ void disableSimon(String name); /** * Lets the Simon to inherit its enable/disable state from its parent. * * @param name name of the Simon */ void inheritState(String name); /** * Retrieves sample data object for a particular Counter. * * @param name name of the Simon * @return sample object or null if Simon with entered name doesn't exist * @see org.javasimon.CounterSample */ CounterSample getCounterSample(String name); /** * Retrieves sample data object for a particular Stopwatch. * * @param name name of the Simon * @return sample object or null if Simon with entered name doesn't exist * @see org.javasimon.StopwatchSample */ StopwatchSample getStopwatchSample(String name); /** * Samples increment in Counter values since the previous call of this method with the * same key. When the method is called the first time for the key, current values * are returned (same like from {@link #getCounterSample(String)} }. Any subsequent calls with the key * provide increments. *

* Clients should use a unique key (GUID, host name, etc.), to avoid interference * with other clients. * * @param name name of the stopwatch * @param key name of an incremental sample * @return sample collected for a specified key if it was created before */ CounterSample getIncrementCounterSample(String name, String key); /** * Samples increment in Stopwatch values since the previous call of this method with the * same key. When the method is called the first time for the key, current values * are returned (same like from {@link #getCounterSample(String)} }. Any subsequent calls with the key * provide increments. *

* Clients should use a unique key (GUID, host name, etc.), to avoid interference * with other clients. * * @param name name of the stopwatch * @param key name of an incremental sample * @return sample collected for a specified key if it was created before */ org.javasimon.jmx.StopwatchSample getIncrementStopwatchSample(String name, String key); /** * Prints multi-line string containing Simon tree starting with the specified Simon to standard output. * * @see org.javasimon.utils.SimonUtils#simonTreeString(org.javasimon.Simon) */ void printSimonTree(); /** * Sample all Counters * * @return One Sample for each Counter */ List getCounterSamples(); /** * Increment sample all Counters. * * @param key name of an incremental sample * @return one Sample for each Counter * @see #getIncrementCounterSample(String, String) */ List getIncrementCounterSamples(String key); /** * Sample all Counters whose name matches given pattern * * @param namePattern Name pattern, null means all Counters * @return One Sample for each Counter */ List getCounterSamples(String namePattern); /** * Incremental sample for all Counters whose name matches given pattern. * * * @param namePattern name pattern ({@link org.javasimon.SimonPattern}), {@code null} means all Counters * @param key name of an incremental sample * @return one Sample for each Counter whose name matches given pattern * @see #getIncrementCounterSample(String, String) */ List getIncrementCounterSamples(String namePattern, String key); /** * Sample all Stopwatches whose name matches given pattern. * * @param namePattern name pattern ({@link org.javasimon.SimonPattern}), {@code null} means all Stopwatches * @return one Sample for each Stopwatch */ List getStopwatchSamples(String namePattern); /** * Increment sample all Stopwatches whose name matches given pattern. * * @param namePattern name pattern ({@link org.javasimon.SimonPattern}), {@code null} means all Stopwatches * @param key name of an incremental sample * @return one Sample for each Stopwatch whose name matches given pattern * @see #getIncrementStopwatchSample(String, String) */ List getIncrementStopwatchSamples(String namePattern, String key); /** * Sample all Stopwatches. * * @return one Sample for each Stopwatch */ List getStopwatchSamples(); /** * Increment sample all Stopwatches. * * @param key name of an incremental sample * @return one Sample for each Stopwatch * @see #getIncrementStopwatchSample(String, String) */ List getIncrementStopwatchSamples(String key); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy