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

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

There is a newer version: 5.5.0
Show newest version
/*
 * Copyright (c) 2008-2016, 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.spi.annotation.Beta;

import static com.hazelcast.config.InMemoryFormat.NATIVE;
import static com.hazelcast.util.Preconditions.checkAsyncBackupCount;
import static com.hazelcast.util.Preconditions.checkBackupCount;
import static com.hazelcast.util.Preconditions.checkFalse;
import static com.hazelcast.util.Preconditions.checkNotNegative;
import static com.hazelcast.util.Preconditions.checkNotNull;
import static com.hazelcast.util.Preconditions.checkPositive;

/**
 * Contains the configuration for the {@link com.hazelcast.ringbuffer.Ringbuffer}.
 * 

* The RingBuffer is currently not a distributed data-structure, so its content will be fully stored on a single member * in the cluster and its backup in another member in the cluster. */ @Beta public class RingbufferConfig { /** * Default value of capacity of the RingBuffer. */ public static final int DEFAULT_CAPACITY = 10 * 1000; /** * Default value of synchronous backup count */ public static final int DEFAULT_SYNC_BACKUP_COUNT = 1; /** * Default value of asynchronous backup count */ public static final int DEFAULT_ASYNC_BACKUP_COUNT = 0; /** * Default value for the time to live property. */ public static final int DEFAULT_TTL_SECONDS = 0; /** * Default value for the InMemoryFormat. */ public static final InMemoryFormat DEFAULT_IN_MEMORY_FORMAT = InMemoryFormat.BINARY; private String name; private int capacity = DEFAULT_CAPACITY; private int backupCount = DEFAULT_SYNC_BACKUP_COUNT; private int asyncBackupCount = DEFAULT_ASYNC_BACKUP_COUNT; private int timeToLiveSeconds = DEFAULT_TTL_SECONDS; private InMemoryFormat inMemoryFormat = DEFAULT_IN_MEMORY_FORMAT; /** * Creates a RingbufferConfig with the provided name. * * @param name the name * @throws java.lang.NullPointerException if name is null */ public RingbufferConfig(String name) { this.name = checkNotNull(name, "name can't be null"); } /** * Clones a RingbufferConfig * * @param config the ringbuffer config to clone * @throws java.lang.NullPointerException if config is null */ public RingbufferConfig(RingbufferConfig config) { checkNotNull(config, "config can't be null"); this.name = config.name; this.capacity = config.capacity; this.backupCount = config.backupCount; this.asyncBackupCount = config.asyncBackupCount; this.timeToLiveSeconds = config.timeToLiveSeconds; this.inMemoryFormat = config.inMemoryFormat; } /** * Creates a new RingbufferConfig by cloning an existing config and overriding the name. * * @param name the new name * @param config the config. * @throws java.lang.NullPointerException if name or config is null. */ public RingbufferConfig(String name, RingbufferConfig config) { this(config); this.name = checkNotNull(name, "name can't be null"); } /** * Returns the name of the ringbuffer. * * @return the name of the ringbuffer. */ public String getName() { return name; } /** * Gets the capacity of the ringbuffer. *

* The capacity is the total number of items in the ringbuffer. The items will remain in the ringbuffer, but the oldest items * will eventually be be overwritten by the newest items. *

* In the future we'll add more advanced policies e.g. based on memory usage or lifespan. * * @return the capacity. */ public int getCapacity() { return capacity; } /** * Sets the capacity of the ringbuffer. * * @param capacity the capacity. * @return the updated Config. * @throws java.lang.IllegalArgumentException if capacity smaller than 1. * @see #getCapacity() */ public RingbufferConfig setCapacity(int capacity) { checkPositive(capacity, "capacity can't be smaller than 1"); this.capacity = capacity; return this; } /** * Gets the number of synchronous backups. * * @return number of synchronous backups. */ public int getBackupCount() { return backupCount; } /** * Sets the number of synchronous backups. * * @param backupCount the number of synchronous backups to set * @return the updated SemaphoreConfig * @throws IllegalArgumentException if backupCount smaller than 0, * or larger than the maximum number of backup * or the sum of the backups and async backups is larger than the maximum number of backups * @see #setAsyncBackupCount(int) * @see #getBackupCount() */ public RingbufferConfig setBackupCount(int backupCount) { this.backupCount = checkBackupCount(backupCount, asyncBackupCount); return this; } /** * Gets the number of asynchronous backups. * * @return the number of asynchronous backups. */ public int getAsyncBackupCount() { return asyncBackupCount; } /** * Sets the number of asynchronous backups. 0 means no backups * * @param asyncBackupCount the number of asynchronous synchronous backups to set * @return the updated SemaphoreConfig * @throws IllegalArgumentException if asyncBackupCount smaller than 0, * or larger than the maximum number of backup * or the sum of the backups and async backups is larger than the maximum number of backups * @see #setBackupCount(int) * @see #getAsyncBackupCount() */ public RingbufferConfig setAsyncBackupCount(int asyncBackupCount) { this.asyncBackupCount = checkAsyncBackupCount(backupCount, asyncBackupCount); return this; } /** * Returns the total number of backups: backupCount plus asyncBackupCount. * * @return the total number of backups: backupCount plus asyncBackupCount */ public int getTotalBackupCount() { return backupCount + asyncBackupCount; } /** * Creates a readonly copy of this RingbufferConfig. * * @return the readonly copy. */ public RingbufferConfig getAsReadOnly() { return new RingbufferConfigReadonly(this); } /** * Gets the time to live in seconds. * * @return the time to live in seconds. Returns 0 the time to live if the items don't expire. */ public int getTimeToLiveSeconds() { return timeToLiveSeconds; } /** * Sets the time to live in seconds. * * Time to live is the time the ringbuffer is going to retain items before deleting them. * * Time to live can be disabled by setting timeToLiveSeconds to 0. It means that items won't get removed because they * retire. They will only overwrite. This means that when timeToLiveSeconds is disabled, that after tail did a full * loop in the ring that the size will always be equal to the capacity. * * @param timeToLiveSeconds the time to live period in seconds * @return the updated RingbufferConfig * @throws IllegalArgumentException if timeToLiveSeconds smaller than 0. */ public RingbufferConfig setTimeToLiveSeconds(int timeToLiveSeconds) { this.timeToLiveSeconds = checkNotNegative(timeToLiveSeconds, "timeToLiveSeconds can't be smaller than 0"); return this; } /** * Gets the InMemoryFormat. * * @return the InMemoryFormat. */ public InMemoryFormat getInMemoryFormat() { return inMemoryFormat; } /** * Sets the InMemoryFormat. * * Setting the InMemoryFormat controls format of storing an item in the ringbuffer: *

    *
  1. {@link InMemoryFormat#OBJECT}: the item is stored in deserialized format (so a regular object)
  2. *
  3. {@link InMemoryFormat#BINARY}: the item is stored in serialized format (so a is binary blob)
  4. *
* * The default is binary. The object InMemoryFormat is useful when: *
    *
  1. of the object stored in object format has a smaller footprint than in binary format
  2. *
  3. if there are readers using a filter. Since for every filter invocation, the object needs to be available in * object format.
  4. *
* * @param inMemoryFormat the new in memory format. * @return the updated Config. * @throws NullPointerException if inMemoryFormat is null. * @throws IllegalArgumentException if {@link InMemoryFormat#NATIVE} in memory format is selected. */ public RingbufferConfig setInMemoryFormat(InMemoryFormat inMemoryFormat) { checkNotNull(inMemoryFormat, "inMemoryFormat can't be null"); checkFalse(inMemoryFormat == NATIVE, "InMemoryFormat " + NATIVE + " is not supported"); this.inMemoryFormat = inMemoryFormat; return this; } @Override public String toString() { return "RingbufferConfig{" + "name='" + name + '\'' + ", capacity=" + capacity + ", backupCount=" + backupCount + ", asyncBackupCount=" + asyncBackupCount + ", timeToLiveSeconds=" + timeToLiveSeconds + ", inMemoryFormat=" + inMemoryFormat + '}'; } /** * A readonly version of the {@link RingbufferConfig}. */ @Beta static class RingbufferConfigReadonly extends RingbufferConfig { public RingbufferConfigReadonly(RingbufferConfig config) { super(config); } @Override public RingbufferConfig setCapacity(int capacity) { throw new UnsupportedOperationException("This config is read-only"); } @Override public RingbufferConfig setAsyncBackupCount(int asyncBackupCount) { throw new UnsupportedOperationException("This config is read-only"); } @Override public RingbufferConfig setBackupCount(int backupCount) { throw new UnsupportedOperationException("This config is read-only"); } @Override public RingbufferConfig setTimeToLiveSeconds(int timeToLiveSeconds) { throw new UnsupportedOperationException("This config is read-only"); } @Override public RingbufferConfig setInMemoryFormat(InMemoryFormat inMemoryFormat) { throw new UnsupportedOperationException("This config is read-only"); } } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy