com.google.api.control.aggregator.CheckAggregationOptions Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of endpoints-management-control Show documentation
Show all versions of endpoints-management-control Show documentation
Provide access control for managed services
/*
* Copyright 2016 Google 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.google.api.control.aggregator;
import com.google.common.base.Preconditions;
import com.google.common.base.Ticker;
import com.google.common.cache.Cache;
import com.google.common.cache.CacheBuilder;
import com.google.common.cache.RemovalListener;
import com.google.common.cache.RemovalNotification;
import java.util.concurrent.ConcurrentLinkedDeque;
import java.util.concurrent.TimeUnit;
import javax.annotation.Nullable;
/**
* Holds values used to configure check aggregation.
*/
public class CheckAggregationOptions {
/**
* The default aggregation cache size.
*/
public static final int DEFAULT_NUM_ENTRIES = 1000;
/**
* The default response expiration interval.
*/
public static final int DEFAULT_RESPONSE_EXPIRATION_MILLIS = 4000;
/**
* The default flush cache entry interval.
*/
public static final int DEFAULT_FLUSH_CACHE_ENTRY_INTERVAL_MILLIS = 2000;
private final int numEntries;
private final int flushCacheEntryIntervalMillis;
private final int expirationMillis;
/**
* Constructor
*
* @param numEntries
* is the maximum number of cache entries that can be kept in the
* aggregation cache. The cache is disabled if this value is
* negative.
* @param flushCacheEntryIntervalMillis
* the maximum interval before an aggregated check request is
* flushed to the server. The cache entry is deleted after the
* flush
* @param expirationMillis
* is the maximum interval in milliseconds before a cached check
* response is invalidated. This value should be greater than
* {@code flushCacheEntryIntervalMillis}. If not, it is ignored,
* and a value of {@code flushCacheEntryIntervalMillis} is used
* instead.
*/
public CheckAggregationOptions(int numEntries, int flushCacheEntryIntervalMillis, int expirationMillis) {
this.numEntries = numEntries;
this.flushCacheEntryIntervalMillis = flushCacheEntryIntervalMillis;
this.expirationMillis = Math.max(expirationMillis, flushCacheEntryIntervalMillis + 1);
}
/**
* No-arg constructor
*
* Creates an instance initialized with the default values.
*/
public CheckAggregationOptions() {
this(DEFAULT_NUM_ENTRIES, DEFAULT_FLUSH_CACHE_ENTRY_INTERVAL_MILLIS, DEFAULT_RESPONSE_EXPIRATION_MILLIS);
}
/**
* @return the maximum number of cache entries that can be kept in the
* aggregation cache.
*/
public int getNumEntries() {
return numEntries;
}
/**
* @return the maximum interval before aggregated report requests are
* flushed to the server
*/
public int getFlushCacheEntryIntervalMillis() {
return flushCacheEntryIntervalMillis;
}
/**
* @return the maximum interval before a cached check response should be
* deleted. This value will not be greater than
* {@link #getFlushCacheEntryIntervalMillis()}
*/
public int getExpirationMillis() {
return expirationMillis;
}
/**
* Creates a {@link Cache} configured by this instance.
*
* @param
* the type of the instance being cached
*
* @param out
* a concurrent {@code Deque} to which previously cached items
* are added as they expire
* @return a {@link Cache} corresponding to this instance's values or
* {@code null} unless {@link #numEntries} is positive.
*/
@Nullable
public Cache createCache(ConcurrentLinkedDeque out) {
return createCache(out, Ticker.systemTicker());
}
/**
* Creates a {@link Cache} configured by this instance.
*
* @param
* the type of the value stored in the Cache
* @param out
* a concurrent {@code Deque} to which the cached values are
* added as they are removed from the cache
* @param ticker
* the time source used to determine expiration
* @return a {@link Cache} corresponding to this instance's values or
* {@code null} unless {@code #numEntries} is positive.
*/
@Nullable
public Cache createCache(final ConcurrentLinkedDeque out, Ticker ticker) {
Preconditions.checkNotNull(out, "The out deque cannot be null");
Preconditions.checkNotNull(ticker, "The ticker cannot be null");
if (numEntries <= 0) {
return null;
}
final RemovalListener listener = new RemovalListener() {
@Override
public void onRemoval(RemovalNotification notification) {
out.addFirst(notification.getValue());
}
};
CacheBuilder b = CacheBuilder.newBuilder().maximumSize(numEntries).ticker(ticker)
.removalListener(listener);
if (expirationMillis >= 0) {
b.expireAfterWrite(expirationMillis, TimeUnit.MILLISECONDS);
}
return b.build();
}
}