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

io.quarkus.cache.runtime.CacheConfig Maven / Gradle / Ivy

package io.quarkus.cache.runtime;

import static io.quarkus.runtime.annotations.ConfigPhase.RUN_TIME;

import java.time.Duration;
import java.util.Map;
import java.util.Optional;
import java.util.OptionalInt;
import java.util.OptionalLong;

import io.quarkus.runtime.annotations.ConfigDocMapKey;
import io.quarkus.runtime.annotations.ConfigDocSection;
import io.quarkus.runtime.annotations.ConfigRoot;
import io.smallrye.config.ConfigMapping;
import io.smallrye.config.WithDefault;
import io.smallrye.config.WithParentName;

@ConfigRoot(phase = RUN_TIME)
@ConfigMapping(prefix = "quarkus.cache")
public interface CacheConfig {

    /**
     * Whether or not the cache extension is enabled.
     */
    @WithDefault("true")
    boolean enabled();

    /**
     * Caffeine configuration.
     */
    CaffeineConfig caffeine();

    interface CaffeineConfig {

        /**
         * Default configuration applied to all Caffeine caches (lowest precedence)
         */
        @WithParentName
        @ConfigDocSection
        CaffeineCacheConfig defaultConfig();

        /**
         * Additional configuration applied to a specific Caffeine cache (highest precedence)
         */
        @WithParentName
        @ConfigDocMapKey("cache-name")
        @ConfigDocSection
        Map cachesConfig();

        interface CaffeineCacheConfig {

            /**
             * Minimum total size for the internal data structures. Providing a large enough estimate at construction time
             * avoids the need for expensive resizing operations later, but setting this value unnecessarily high wastes memory.
             */
            OptionalInt initialCapacity();

            /**
             * Maximum number of entries the cache may contain. Note that the cache may evict an entry before this limit is
             * exceeded or temporarily exceed the threshold while evicting. As the cache size grows close to the maximum,
             * the cache evicts entries that are less likely to be used again. For example, the cache may evict an entry because
             * it hasn't been used recently or very often.
             */
            OptionalLong maximumSize();

            /**
             * Specifies that each entry should be automatically removed from the cache once a fixed duration has elapsed after
             * the entry's creation, or the most recent replacement of its value.
             */
            Optional expireAfterWrite();

            /**
             * Specifies that each entry should be automatically removed from the cache once a fixed duration has elapsed after
             * the entry's creation, the most recent replacement of its value, or its last read.
             */
            Optional expireAfterAccess();

            /**
             * Whether or not metrics are recorded if the application depends on the Micrometer extension. Setting this
             * value to {@code true} will enable the accumulation of cache stats inside Caffeine.
             */
            Optional metricsEnabled();
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy