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

net.sf.ehcache.statistics.LiveCacheStatisticsData Maven / Gradle / Ivy

/**
 *  Copyright Terracotta, Inc.
 *
 *  Licensed under the Apache License, Version 2.0 (the "License");
 *  you may not use this file except in compliance with the License.
 *  You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 *  Unless required by applicable law or agreed to in writing, software
 *  distributed under the License is distributed on an "AS IS" BASIS,
 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *  See the License for the specific language governing permissions and
 *  limitations under the License.
 */
package net.sf.ehcache.statistics;

import net.sf.ehcache.event.CacheEventListener;

/**
 * Interface that classes storing usage statistics of a Cache will implement
 *
 * @author Abhishek Sanoujam
 * @since 1.7
 */
public interface LiveCacheStatisticsData extends CacheEventListener {

    /**
     * Enabled/Disabled statistics
     *
     * @param enableStatistics
     */
    void setStatisticsEnabled(final boolean enableStatistics);

    /**
     * Clear existing statistics
     */
    void clearStatistics();

    /**
     * Called on a cache hit in the MemoryStore
     */
    void cacheHitInMemory();

    /**
     * Called on a cache hit in the off-heap
     */
    void cacheHitOffHeap();

    /**
     * Called on a cache hit in the DiskStore
     */
    void cacheHitOnDisk();

    /**
     * Called when an element is not found in the cache
     */
    void cacheMissNotFound();

    /**
     * Called on a cache miss in the MemoryStore
     */
    void cacheMissInMemory();

    /**
     * Called on a cache miss in the off-heap
     */
    void cacheMissOffHeap();

    /**
     * Called on a cache miss in the DiskStore
     */
    void cacheMissOnDisk();

    /**
     * Called when an element is found in the cache but already expired
     */
    void cacheMissExpired();

    /**
     * Called when the Cache's XAResource has been asked to commit
     */
    void xaCommit();

    /**
     * Called when the Cache's XAResource has been asked to rollback
     */
    void xaRollback();

    /**
     * Called when the Cache's XAResource has recovered one or more XID
     */
    void xaRecovered(int count);

    /**
     * Adds time taken for a get operation in the cache
     *
     * @param millis
     * @deprecated
     */
    @Deprecated
    void addGetTimeMillis(final long millis);

    /**
     * Adds time taken for a get operation in the cache
     *
     * @param nanos
     */
    void addGetTimeNanos(final long nanos);

    /**
     * Sets the statistics accuracy.
     *
     * @param statisticsAccuracy
     *            one of Statistics#STATISTICS_ACCURACY_BEST_EFFORT,
     *            Statistics#STATISTICS_ACCURACY_GUARANTEED,
     *            Statistics#STATISTICS_ACCURACY_NONE
     */
    void setStatisticsAccuracy(int statisticsAccuracy);

    /**
     * Registers a {@link CacheUsageListener} which will be notified of the
     * cache
     * usage.
     * Implementations of {@link CacheUsageListener} should override the {@link Object#equals(Object)} and {@link Object#hashCode()} methods
     * as it is used for
     * equality check
     *
     * @throws IllegalStateException
     * @since 1.7
     */
    void registerCacheUsageListener(CacheUsageListener cacheUsageListener) throws IllegalStateException;

    /**
     * Remove an already registered {@link CacheUsageListener}, if any.
     * Depends on the {@link Object#equals(Object)} method.
     *
     * @throws IllegalStateException
     * @since 1.7
     */
    void removeCacheUsageListener(CacheUsageListener cacheUsageListener) throws IllegalStateException;

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy