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

org.infinispan.configuration.cache.StoreAsBinaryConfigurationBuilder Maven / Gradle / Ivy

There is a newer version: 9.1.7.Final
Show newest version
package org.infinispan.configuration.cache;

import org.infinispan.commons.configuration.Builder;
import org.infinispan.configuration.global.GlobalConfiguration;

/**
 * Controls whether when stored in memory, keys and values are stored as references to their original objects, or in
 * a serialized, binary format.  There are benefits to both approaches, but often if used in a clustered mode,
 * storing objects as binary means that the cost of serialization happens early on, and can be amortized.  Further,
 * deserialization costs are incurred lazily which improves throughput.
 * 

* It is possible to control this on a fine-grained basis: you can choose to just store keys or values as binary, or * both. *

* @see StoreAsBinaryConfiguration */ public class StoreAsBinaryConfigurationBuilder extends AbstractConfigurationChildBuilder implements Builder { private boolean enabled = false; private boolean storeKeysAsBinary = true; private boolean storeValuesAsBinary = true; StoreAsBinaryConfigurationBuilder(ConfigurationBuilder builder) { super(builder); } /** * Enables storing both keys and values as binary. */ public StoreAsBinaryConfigurationBuilder enable() { enabled = true; return this; } /** * Disables storing both keys and values as binary. */ public StoreAsBinaryConfigurationBuilder disable() { enabled = false; return this; } /** * Sets whether this feature is enabled or disabled. * @param enabled if true, this feature is enabled. If false, it is disabled. */ public StoreAsBinaryConfigurationBuilder enabled(boolean enabled) { this.enabled = enabled; return this; } /** * Specify whether keys are stored as binary or not. * @param storeKeysAsBinary if true, keys are stored as binary. If false, keys are stored as object references. */ public StoreAsBinaryConfigurationBuilder storeKeysAsBinary(boolean storeKeysAsBinary) { this.storeKeysAsBinary = storeKeysAsBinary; return this; } /** * Specify whether values are stored as binary or not. * @param storeValuesAsBinary if true, values are stored as binary. If false, values are stored as object references. */ public StoreAsBinaryConfigurationBuilder storeValuesAsBinary(boolean storeValuesAsBinary) { this.storeValuesAsBinary = storeValuesAsBinary; return this; } /** * When defensive copying is disabled, Infinispan keeps object references * around and marshalls keys lazily. So clients can modify entries via * original object references, and marshalling only happens when entries * are to be replicated/distributed, or stored in a cache store. * * Since client references are valid, clients can make changes to entries * in the cache using those references, but these modifications are only * local and you still need to call one of the cache's put/replace... * methods in order for changes to replicate. * * When defensive copies are enabled, Infinispan marshalls objects the * moment they're stored, hence changes made to object references are * not stored in the cache, not even for local caches. * * @param defensive boolean indicating whether defensive copies * should be enabled cache wide * @return a configuration builder for fluent programmatic configuration * @deprecated Store as binary configuration is always defensive now. */ @Deprecated public StoreAsBinaryConfigurationBuilder defensive(boolean defensive) { return this; } @Override public void validate() { // Nothing to validate. } @Override public void validate(GlobalConfiguration globalConfig) { } @Override public StoreAsBinaryConfiguration create() { return new StoreAsBinaryConfiguration( enabled, storeKeysAsBinary, storeValuesAsBinary); } @Override public StoreAsBinaryConfigurationBuilder read(StoreAsBinaryConfiguration template) { this.enabled = template.enabled(); this.storeKeysAsBinary = template.storeKeysAsBinary(); this.storeValuesAsBinary = template.storeValuesAsBinary(); return this; } @Override public String toString() { return "StoreAsBinaryConfigurationBuilder{" + "enabled=" + enabled + ", storeKeysAsBinary=" + storeKeysAsBinary + ", storeValuesAsBinary=" + storeValuesAsBinary + '}'; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy