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

com.hazelcast.config.MapStoreConfig Maven / Gradle / Ivy

There is a newer version: 62
Show newest version
/*
 * Copyright (c) 2008-2020, Hazelcast, Inc. All Rights Reserved.
 *
 * 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 com.hazelcast.config;

import com.hazelcast.internal.config.ConfigDataSerializerHook;
import com.hazelcast.map.MapStore;
import com.hazelcast.nio.ObjectDataInput;
import com.hazelcast.nio.ObjectDataOutput;
import com.hazelcast.nio.serialization.IdentifiedDataSerializable;
import com.hazelcast.spi.properties.ClusterProperty;

import javax.annotation.Nonnull;
import java.io.IOException;
import java.util.Objects;
import java.util.Properties;

import static com.hazelcast.internal.util.Preconditions.checkHasText;
import static com.hazelcast.internal.util.Preconditions.checkNotNull;

/**
 * Contains the configuration for a Map Store.
 */
@SuppressWarnings("checkstyle:methodcount")
public class MapStoreConfig implements IdentifiedDataSerializable {
    /**
     * Default delay seconds for writing
     */
    public static final int DEFAULT_WRITE_DELAY_SECONDS = 0;
    /**
     * Default batch size for writing
     */
    public static final int DEFAULT_WRITE_BATCH_SIZE = 1;
    /**
     * Default write coalescing behavior
     */
    public static final boolean DEFAULT_WRITE_COALESCING = true;

    private boolean enabled = true;
    private boolean writeCoalescing = DEFAULT_WRITE_COALESCING;
    private int writeDelaySeconds = DEFAULT_WRITE_DELAY_SECONDS;
    private int writeBatchSize = DEFAULT_WRITE_BATCH_SIZE;
    private String className;
    private String factoryClassName;
    private Object implementation;
    private Object factoryImplementation;
    private Properties properties = new Properties();
    private InitialLoadMode initialLoadMode = InitialLoadMode.LAZY;

    /**
     * Initial load module
     */
    public enum InitialLoadMode {
        /**
         * Each partition is loaded when it is first touched.
         */
        LAZY,
        /**
         * getMap() method does not return till the map is completely loaded.
         */
        EAGER
    }

    public MapStoreConfig() {
    }

    public MapStoreConfig(MapStoreConfig config) {
        enabled = config.isEnabled();
        className = config.getClassName();
        implementation = config.getImplementation();
        factoryClassName = config.getFactoryClassName();
        factoryImplementation = config.getFactoryImplementation();
        writeDelaySeconds = config.getWriteDelaySeconds();
        writeBatchSize = config.getWriteBatchSize();
        initialLoadMode = config.getInitialLoadMode();
        writeCoalescing = config.isWriteCoalescing();
        properties.putAll(config.getProperties());
    }

    /**
     * Returns the name of the MapStore implementation class
     *
     * @return the name of the MapStore implementation class
     */
    public String getClassName() {
        return className;
    }

    /**
     * Sets the name for the MapStore implementation class
     *
     * @param className the name to set for the MapStore implementation class
     */
    public MapStoreConfig setClassName(@Nonnull String className) {
        this.className = checkHasText(className, "Map store class name must contain text");
        this.implementation = null;
        return this;
    }

    /**
     * Returns the name of the MapStoreFactory implementation class
     *
     * @return the name of the MapStoreFactory implementation class
     */
    public String getFactoryClassName() {
        return factoryClassName;
    }

    /**
     * Sets the name for the MapStoreFactory implementation class
     *
     * @param factoryClassName the name to set for the MapStoreFactory implementation class
     */
    public MapStoreConfig setFactoryClassName(@Nonnull String factoryClassName) {
        this.factoryClassName = checkHasText(factoryClassName, "Map store factory class name must contain text");
        this.factoryImplementation = null;
        return this;
    }

    /**
     * Returns the number of seconds to delay the store writes.
     *
     * @return the number of seconds to delay the store writes
     */
    public int getWriteDelaySeconds() {
        return writeDelaySeconds;
    }

    /**
     * Sets the number of seconds to delay before writing (storing) the dirty records
     * 

* Default value is {@value #DEFAULT_WRITE_DELAY_SECONDS}. * * @param writeDelaySeconds the number of seconds to delay before writing the dirty records */ public MapStoreConfig setWriteDelaySeconds(int writeDelaySeconds) { this.writeDelaySeconds = writeDelaySeconds; return this; } /** * Returns the number of operations to be included in each batch processing round. * * @return write batch size: the number of operations to be included in each batch processing round */ public int getWriteBatchSize() { return writeBatchSize; } /** * Sets the number of operations to be included in each batch processing round. *

* Default value is {@value #DEFAULT_WRITE_BATCH_SIZE}. * * @param writeBatchSize the number of operations to be included in each batch processing round */ public MapStoreConfig setWriteBatchSize(int writeBatchSize) { if (writeBatchSize < 1) { throw new IllegalArgumentException("Write batch size should be at least 1"); } this.writeBatchSize = writeBatchSize; return this; } /** * Returns if this configuration is enabled * * @return {@code true} if this configuration is enabled, {@code false} otherwise */ public boolean isEnabled() { return enabled; } /** * Enables and disables this configuration * * @param enabled {@code true} to enables this configuration, {@code false} to disable */ public MapStoreConfig setEnabled(boolean enabled) { this.enabled = enabled; return this; } /** * Sets the map store implementation object * * @param implementation the map store implementation object to set * @return this MapStoreConfig instance */ public MapStoreConfig setImplementation(@Nonnull Object implementation) { this.implementation = checkNotNull(implementation, "Map store cannot be null!"); this.className = null; return this; } /** * Returns the map store implementation object. * * @return the map store implementation object */ public Object getImplementation() { return implementation; } /** * Sets the map store factory implementation object. * * @param factoryImplementation the factory implementation object * @return this MapStoreConfig instance */ public MapStoreConfig setFactoryImplementation(@Nonnull Object factoryImplementation) { this.factoryImplementation = checkNotNull(factoryImplementation, "Map store factory cannot be null!"); this.factoryClassName = null; return this; } /** * Returns the map store factory implementation object. * * @return the map store factory implementation object */ public Object getFactoryImplementation() { return factoryImplementation; } public MapStoreConfig setProperty(String name, String value) { properties.put(name, value); return this; } /** * Returns the given property * * @return the given property */ public String getProperty(String name) { return properties.getProperty(name); } /** * Returns all the properties * * @return all the properties */ public Properties getProperties() { return properties; } /** * Sets the properties * * @param properties the properties to be set * @return this MapStoreConfig */ public MapStoreConfig setProperties(Properties properties) { this.properties = checkNotNull(properties, "Map store config properties cannot be null!"); return this; } /** * Returns the initial load mode. * * @return the initial load mode object */ public InitialLoadMode getInitialLoadMode() { return initialLoadMode; } /** * Sets the initial load mode. *

    *
  • LAZY: Default load mode where load is async
  • *
  • EAGER: load mode where load is blocked till all partitions are loaded
  • *
* * @param initialLoadMode the initial load mode object */ public MapStoreConfig setInitialLoadMode(InitialLoadMode initialLoadMode) { this.initialLoadMode = initialLoadMode; return this; } /** * Returns {@code true} if write-coalescing is enabled. * * @return {@code true} if coalescing enabled, {@code false} otherwise * @see #setWriteCoalescing(boolean) */ public boolean isWriteCoalescing() { return writeCoalescing; } /** * Setting {@link #writeCoalescing} is meaningful * if you are using write-behind {@link MapStore}. *

* When {@link #writeCoalescing} is {@code true}, only the latest * store operation on a key in the {@link #writeDelaySeconds} * time-window will be reflected to {@link MapStore}. *

* Default value is {@value #DEFAULT_WRITE_COALESCING}. * * @param writeCoalescing {@code true} to enable * write-coalescing, otherwise {@code false}. * @see ClusterProperty#MAP_WRITE_BEHIND_QUEUE_CAPACITY */ public MapStoreConfig setWriteCoalescing(boolean writeCoalescing) { this.writeCoalescing = writeCoalescing; return this; } @Override public String toString() { return "MapStoreConfig{" + "enabled=" + enabled + ", className='" + className + '\'' + ", factoryClassName='" + factoryClassName + '\'' + ", writeDelaySeconds=" + writeDelaySeconds + ", writeBatchSize=" + writeBatchSize + ", implementation=" + implementation + ", factoryImplementation=" + factoryImplementation + ", properties=" + properties + ", initialLoadMode=" + initialLoadMode + ", writeCoalescing=" + writeCoalescing + '}'; } @Override public final boolean equals(Object o) { if (this == o) { return true; } if (!(o instanceof MapStoreConfig)) { return false; } MapStoreConfig that = (MapStoreConfig) o; return enabled == that.enabled && writeCoalescing == that.writeCoalescing && writeDelaySeconds == that.writeDelaySeconds && writeBatchSize == that.writeBatchSize && Objects.equals(implementation, that.implementation) && Objects.equals(className, that.className) && Objects.equals(factoryImplementation, that.factoryImplementation) && Objects.equals(factoryClassName, that.factoryClassName) && properties.equals(that.properties) && initialLoadMode == that.initialLoadMode; } @Override public final int hashCode() { return Objects.hash(enabled, writeCoalescing, implementation, className, factoryImplementation, factoryClassName, writeDelaySeconds, writeBatchSize, properties, initialLoadMode); } @Override public int getFactoryId() { return ConfigDataSerializerHook.F_ID; } @Override public int getClassId() { return ConfigDataSerializerHook.MAP_STORE_CONFIG; } @Override public void writeData(ObjectDataOutput out) throws IOException { out.writeBoolean(enabled); out.writeBoolean(writeCoalescing); out.writeUTF(className); out.writeUTF(factoryClassName); out.writeInt(writeDelaySeconds); out.writeInt(writeBatchSize); out.writeObject(implementation); out.writeObject(factoryImplementation); out.writeObject(properties); out.writeUTF(initialLoadMode.name()); } @Override public void readData(ObjectDataInput in) throws IOException { enabled = in.readBoolean(); writeCoalescing = in.readBoolean(); className = in.readUTF(); factoryClassName = in.readUTF(); writeDelaySeconds = in.readInt(); writeBatchSize = in.readInt(); implementation = in.readObject(); factoryImplementation = in.readObject(); properties = in.readObject(); initialLoadMode = InitialLoadMode.valueOf(in.readUTF()); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy