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

org.infinispan.functional.Param Maven / Gradle / Ivy

package org.infinispan.functional;

import org.infinispan.commons.util.Experimental;
import org.infinispan.functional.impl.Params;

/**
 * An easily extensible parameter that allows functional map operations to be
 * tweaked. Examples would include local-only parameter, skip-cache-store parameter and others.
 *
 * 

What makes {@link Param} different from {@link MetaParam} is that {@link Param} * values are never stored in the functional map. They merely act as ways to * tweak how operations are executed. * *

Since {@link Param} instances control how the internals work, only * {@link Param} implementations by Infinispan will be supported. * *

This interface is equivalent to Infinispan's Flag, but it's more * powerful because it allows to pass a flag along with a value. Infinispan's * Flag are enum based which means no values can be passed along with value. * *

Since each param is an independent entity, it's easy to create * public versus private parameter distinction. When parameters are stored in * enums, it's more difficult to make such distinction. * * @param

type of parameter * @since 8.0 */ @Experimental public interface Param

{ /** * A parameter's identifier. Each parameter must have a different id. * *

A numeric id makes it flexible enough to be stored in collections that * take up low resources, such as arrays. */ int id(); /** * Parameter's value. */ P get(); /** * When a persistence store is attached to a cache, by default all write * operations, regardless of whether they are inserts, updates or removes, * are persisted to the store. Using {@link #SKIP}, the write operations * can skip the persistence store modification, applying the effects of * the write operation only in the in-memory contents of the caches in * the cluster. * * @apiNote Previously this flag had only two options; PERSIST and SKIP * since it was assumed that an implementation can use write-only command * when it is not interested in the previous value. However sometimes * we are interested in the memory-only data but cannot afford to load it * from persistence. * * @since 8.0 */ @Experimental enum PersistenceMode implements Param { LOAD_PERSIST, SKIP_PERSIST, SKIP_LOAD, SKIP; public static final int ID = ParamIds.PERSISTENCE_MODE_ID; private static final PersistenceMode[] CACHED_VALUES = values(); @Override public int id() { return ID; } @Override public PersistenceMode get() { return this; } /** * Provides default persistence mode. */ public static PersistenceMode defaultValue() { return LOAD_PERSIST; } public static PersistenceMode valueOf(int ordinal) { return CACHED_VALUES[ordinal]; } } /** * Normally the cache has to acquire locks during any write operation to guarantee * its correctness. If the application is sure that no concurrent operation occurs, * it is possible to increase performance by setting this param to {@link #SKIP}. * The result of any operation without locking is undefined under presence of concurrent * writes. */ @Experimental enum LockingMode implements Param { LOCK, SKIP, /** * The operation fails when it is not possible to acquire the lock without waiting. */ TRY_LOCK; public static final int ID = ParamIds.LOCKING_MODE_ID; private static final LockingMode[] CACHED_VALUES = values(); @Override public int id() { return ID; } @Override public LockingMode get() { return this; } public static LockingMode defaultValue() { return LOCK; } public static LockingMode valueOf(int ordinal) { return CACHED_VALUES[ordinal]; } } /** * Defines where is the command executed. */ @Experimental enum ExecutionMode implements Param { /** * Command is executed on its owners, in transactional mode in the context, too, but there it is not persisted. * The result of the command is backed up to all sites configured for backup. * Note: under some circumstances it may be necessary to transfer full value instead of executing the command * on some owners; the application must not rely on any side effects of command execution. */ ALL, /** * Command is executed only locally, it is not sent to remote nodes. If the command is a write and this node * is not an owner of given entry, the entry is not stored in the cache; if the node is an owner the entry is * stored (even without contacting the primary owner, if this is a backup). If the command reads a value and * the entry is not available locally, null entry is provided instead. */ LOCAL, /** * Command is executed only in the current site (same as {@link #ALL}, but it is not sent for backup * to other sites) */ LOCAL_SITE; // Other options: context-only write, write without remote read (SKIP_REMOTE_LOOKUP)... public static final int ID = ParamIds.EXECUTION_MODE_ID; private static final ExecutionMode[] CACHED_VALUES = values(); @Override public int id() { return ID; } @Override public ExecutionMode get() { return this; } public static ExecutionMode defaultValue() { return ALL; } public static ExecutionMode valueOf(int ordinal) { return CACHED_VALUES[ordinal]; } } /** * Defines how statistics are gathered for this command. */ @Experimental enum StatisticsMode implements Param { /** * Statistics from this command are recorded */ GATHER, /** * Statistics from this command are not recorded */ SKIP; public static final int ID = ParamIds.STATS_MODE_ID; private static final StatisticsMode[] CACHED_VALUES = values(); @Override public int id() { return ID; } @Override public StatisticsMode get() { return this; } public static StatisticsMode defaultValue() { return GATHER; } public static StatisticsMode valueOf(int ordinal) { return CACHED_VALUES[ordinal]; } public static boolean isSkip(Params params) { return params.get(ID).get() == SKIP; } } @Experimental enum ReplicationMode implements Param { /** * Command is completed when all owners are updated. */ SYNC, /** * Invoking node does not know when the owners are updated nor if the command fails. */ ASYNC; public static final int ID = ParamIds.REPLICATION_MODE_ID; public static final ReplicationMode[] CACHED_VALUES = values(); @Override public int id() { return ID; } @Override public ReplicationMode get() { return this; } public static ReplicationMode defaultValue() { return SYNC; } public static ReplicationMode valueOf(int ordinal) { return CACHED_VALUES[ordinal]; } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy