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

alluxio.client.file.cache.store.MemoryPageStoreDir Maven / Gradle / Ivy

/*
 * The Alluxio Open Foundation licenses this work under the Apache License, version 2.0
 * (the "License"). You may not use this work except in alluxio.shaded.client.com.liance with the License, which is
 * available at www.apache.alluxio.shaded.client.org.licenses/LICENSE-2.0
 *
 * This software is distributed on an "AS IS" basis, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
 * either express or implied, as more fully set forth in the License.
 *
 * See the NOTICE file distributed with this work for information regarding copyright ownership.
 */

package alluxio.client.file.cache.store;

import static java.util.Objects.requireNonNull;

import alluxio.client.file.cache.CacheUsage;
import alluxio.client.file.cache.PageInfo;
import alluxio.client.file.cache.PageStore;
import alluxio.client.file.cache.evictor.CacheEvictor;

import java.util.Optional;
import java.util.function.Consumer;

/**
 * Represents the dir and file level metadata of the MemPageStore.
 */
public class MemoryPageStoreDir extends QuotaManagedPageStoreDir {

  private final MemoryPageStore mPageStore;

  /**
   * Constructor of MemPageStoreDir.
   *
   * @param pageStoreOptions page store options
   * @param pageStore the PageStore instance
   * @param cacheEvictor the evictor
   */
  public MemoryPageStoreDir(PageStoreOptions pageStoreOptions,
                            MemoryPageStore pageStore,
                            CacheEvictor cacheEvictor) {
    super(pageStoreOptions.getRootDir(),
        (long) (pageStoreOptions.getCacheSize() / (1 + pageStoreOptions.getOverheadRatio())),
        cacheEvictor);
    mPageStore = requireNonNull(pageStore);
  }

  @Override
  public PageStore getPageStore() {
    return mPageStore;
  }

  @Override
  public void reset() {
    mPageStore.reset();
  }

  @Override
  public void scanPages(Consumer> pageInfoConsumer) {
    //do nothing
  }

  @Override
  public Optional getUsage() {
    return Optional.of(new QuotaManagedPageStoreDir.Usage());
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy