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

de.schlichtherle.truezip.extension.pace.PaceManager Maven / Gradle / Ivy

Go to download

This module constrains the number of mounted archive files in order to save some heap space. It provides a JMX interface for monitoring and management. Add the JAR artifact of this module to the run time class path to make its services available for service location in the client API modules.

There is a newer version: 7.7.10
Show newest version
/*
 * Copyright (C) 2005-2015 Schlichtherle IT Services.
 * All rights reserved. Use is subject to license terms.
 */
package de.schlichtherle.truezip.extension.pace;

import de.schlichtherle.truezip.fs.FsSyncException;
import javax.management.MXBean;

/**
 * The pace manager MXBean interface.
 * 
 * @author Christian Schlichtherle
 */
@MXBean
public interface PaceManager {

    /**
     * The name of the property for the maximum number of file systems which
     * may have been mounted at any time, which is {@value}.
     */
    String MAXIMUM_FILE_SYSTEMS_MOUNTED_PROPERTY_NAME
            = "maximumFileSystemsMounted";

    /**
     * The key string for the system property which defines the value of the
     * constant {@link #MAXIMUM_FILE_SYSTEMS_MOUNTED_DEFAULT_VALUE}.
     * Equivalent to the expression
     * {@code PaceManager.class.getName() + "." + MAXIMUM_FILE_SYSTEMS_MOUNTED_PROPERTY_NAME}.
     */
    String MAXIMUM_FILE_SYSTEMS_MOUNTED_PROPERTY_KEY
            = PaceManager.class.getName() + "." + MAXIMUM_FILE_SYSTEMS_MOUNTED_PROPERTY_NAME;

    /**
     * The minimum value for the maximum number of mounted file systems, which
     * is {@value}.
     */
    int MAXIMUM_FILE_SYSTEMS_MOUNTED_MINIMUM_VALUE = 2;

    /**
     * The default value for the maximum number of mounted file systems.
     * The value of this constant will be set to
     * {@link #MAXIMUM_FILE_SYSTEMS_MOUNTED_MINIMUM_VALUE} unless a system
     * property with the key string
     * {@link #MAXIMUM_FILE_SYSTEMS_MOUNTED_PROPERTY_KEY}
     * is set to a value which is greater than
     * {@code MAXIMUM_FILE_SYSTEMS_MOUNTED_MINIMUM_VALUE}.
     * 

* Mind you that this constant is initialized when this interface is loaded * and cannot accurately reflect the value in a remote JVM instance. */ int MAXIMUM_FILE_SYSTEMS_MOUNTED_DEFAULT_VALUE = Math.max(MAXIMUM_FILE_SYSTEMS_MOUNTED_MINIMUM_VALUE, Integer.getInteger(MAXIMUM_FILE_SYSTEMS_MOUNTED_PROPERTY_KEY, MAXIMUM_FILE_SYSTEMS_MOUNTED_MINIMUM_VALUE)); /** * Returns the total number of file systems. * * @return The total number of file systems. */ int getFileSystemsTotal(); /** * Returns the number of file systems * which have been mounted and need synchronization by calling * {@link #sync}. * The value of this property never exceeds * {@link #getMaximumFileSystemsMounted()}. *

* Note that you should not use the returned value to synchronize * conditionally - this would be unreliable! * * @return The number of mounted file systems. */ int getFileSystemsMounted(); /** * Returns the maximum number of file systems which may have been mounted * at any time. * The mimimum value is {@link #MAXIMUM_FILE_SYSTEMS_MOUNTED_MINIMUM_VALUE}. * The default value is {@link #MAXIMUM_FILE_SYSTEMS_MOUNTED_DEFAULT_VALUE}. * * @return The maximum number of mounted file systems. */ int getMaximumFileSystemsMounted(); /** * Sets the maximum number of file systems which may have been mounted * at any time. * Changing this property will show effect upon the next access to any * file system. * * @param maxMounted the maximum number of mounted file systems. * @throws IllegalArgumentException if {@code maxMounted} is less than * {@link #MAXIMUM_FILE_SYSTEMS_MOUNTED_MINIMUM_VALUE}. */ void setMaximumFileSystemsMounted(int maxMounted); /** * Returns the total number of top level archive file systems. * The value of this property never exceeds * {@link #getFileSystemsTotal()}. * * @return The total number of top level archive file systems. */ int getTopLevelArchiveFileSystemsTotal(); /** * Returns the number of top level archive file systems * which have been mounted and need synchronization by calling * {@link #sync}. * The value of this property never exceeds * {@link #getFileSystemsMounted()}. *

* Note that you should not use the returned value to synchronize * conditionally - this would be unreliable! * * @return The number of mounted top level archive file systems. */ int getTopLevelArchiveFileSystemsMounted(); /** * Synchronizes all file systems. * As a side effect, upon successful operation, the value of the properties * {@link #getFileSystemsMounted()} is reset to zero. * * @throws FsSyncException if the synchronization fails for some reason. */ void sync() throws FsSyncException; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy