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

org.sirix.cache.GuavaCache Maven / Gradle / Ivy

Go to download

SirixDB is a hybrid on-disk and in-memory document oriented, versioned database system. It has a lightweight buffer manager, stores everything in a huge persistent and durable tree and allows efficient reconstruction of every revision. Furthermore, SirixDB implements change tracking, diffing and supports time travel queries.

There is a newer version: 0.11.0
Show newest version
// package org.sirix.cache;
//
// import static com.google.common.base.Preconditions.checkNotNull;
// import com.google.common.cache.CacheBuilder;
// import com.google.common.cache.CacheLoader;
// import com.google.common.cache.LoadingCache;
// import com.google.common.cache.RemovalListener;
// import com.google.common.cache.RemovalNotification;
// import com.google.common.collect.ImmutableMap;
//
// import java.util.Map;
// import java.util.concurrent.ConcurrentMap;
// import java.util.concurrent.ExecutionException;
// import java.util.concurrent.TimeUnit;
//
// import org.checkerframework.checker.nullness.qual.NonNull;
// import org.checkerframework.checker.nullness.qual.Nullable;
//
// import org.sirix.api.PageReadTrx;
// import org.sirix.exception.SirixIOException;
// import org.sirix.page.PageKind;
//
/// **
// * Cache utilizing the Guava cache functionality.
// *
// * @author Johannes Lichtenberger, University of Konstanz
// *
// */
// public class GuavaCache implements Cache {
//
// /**
// * Determines after how many seconds to expire entries after the last access.
// */
// private static final int EXPIRE_AFTER = 15;
//
// /**
// * Maximum cache size.
// */
// private static final int MAX_SIZE = 20;
//
// /**
// * {@link LoadingCache} reference.
// */
// private final LoadingCache mCache;
//
// /**
// * Second cache.
// */
// private final Cache mSecondCache;
//
// /**
// * Constructor with second cache.
// *
// * @param pageReadTransaction
// * {@link PageReadTrx} implementation
// * @param secondCache
// * second fallback cache
// */
// public GuavaCache(final PageReadTrx pageReadTransaction,
// final Cache secondCache) {
// checkNotNull(pageReadTransaction);
// mSecondCache = checkNotNull(secondCache);
//
// final CacheBuilder builder = CacheBuilder.newBuilder()
// .maximumSize(MAX_SIZE)
// .expireAfterAccess(EXPIRE_AFTER, TimeUnit.SECONDS);
// builder.removalListener(new RemovalListener() {
// @Override
// public void onRemoval(
// @Nullable final RemovalNotification pRemoval) {
// if (pRemoval != null) {
// final Tuple tuple = pRemoval.getKey();
// final RecordPageContainer pageCont = pRemoval.getValue();
// if (tuple != null && pageCont != null)
// secondCache.put(tuple, pageCont);
// }
// }
// });
// mCache = builder.build(new CacheLoader() {
// @Override
// public RecordPageContainer load(final @Nullable Tuple key)
// throws SirixIOException {
// if (key == null) {
// return RecordPageContainer.EMPTY_INSTANCE;
// }
// final long nodePageKey = key.getKey();
// final PageKind pageType = key.getPage();
// if (pageType == null) {
// return RecordPageContainer.EMPTY_INSTANCE;
// } else {
// return pageReadTransaction.getNodeFromPage(nodePageKey, pageType);
// }
// }
// });
// }
//
// /**
// * Constructor with an always empty second cache.
// *
// * @param pageReadTransaction
// * {@link PageReadTrx} implementation to read pages
// */
// public GuavaCache(final PageReadTrx pageReadTransaction) {
// this(pageReadTransaction, new EmptyCache());
// }
//
// @Override
// public void clear() {
// mCache.invalidateAll();
// mCache.cleanUp();
// }
//
// @Override
// public synchronized RecordPageContainer get(final Tuple key) {
// try {
// if (key.getKey() < 0) {
// return RecordPageContainer.EMPTY_INSTANCE;
// }
// RecordPageContainer container = mCache.getIfPresent(key);
// if (container != null
// && container.equals(RecordPageContainer.EMPTY_INSTANCE)) {
// mCache.invalidate(key);
// container = mCache.get(key);
// } else if (container == null) {
// container = mCache.get(key);
// if (container == null) {
// container = mSecondCache.get(key);
// }
// }
// assert container != null;
// return container;
// } catch (final ExecutionException e) {
// throw new IllegalStateException(e);
// }
// }
//
// @Override
// public void put(final Tuple key,
// final RecordPageContainer value) {
// mCache.put(key, value);
// }
//
// @Override
// public ImmutableMap getAll(
// final Iterable keys) {
// try {
// return mCache.getAll(keys);
// } catch (final ExecutionException e) {
// throw new IllegalStateException(e);
// }
// }
//
// @Override
// public void toSecondCache() {
// final ConcurrentMap cached = mCache.asMap();
// mSecondCache.putAll(cached);
// }
//
// @Override
// public void putAll(final Map map) {
// mCache.putAll(map);
// }
//
// @Override
// public void remove(final Tuple key) {
// mCache.invalidate(key);
// }
//
// @Override
// public void close() {
// mCache.cleanUp();
// mSecondCache.close();
// }
// }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy