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

alluxio.master.MasterUtils Maven / Gradle / Ivy

The newest version!
/*
 * The Alluxio Open Foundation licenses this work under the Apache License, version 2.0
 * (the "License"). You may not use this work except in compliance with the License, which is
 * available at www.apache.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.master;

import alluxio.Constants;
import alluxio.conf.Configuration;
import alluxio.conf.PropertyKey;
import alluxio.master.metastore.BlockMetaStore;
import alluxio.master.metastore.InodeStore;
import alluxio.master.metastore.MetastoreType;
import alluxio.master.metastore.caching.CachingInodeStore;
import alluxio.master.metastore.heap.HeapBlockMetaStore;
import alluxio.master.metastore.heap.HeapInodeStore;
import alluxio.master.metastore.rocks.RocksBlockMetaStore;
import alluxio.master.metastore.rocks.RocksInodeStore;
import alluxio.util.CommonUtils;

import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.Callable;

/**
 * This class encapsulates the different master services that are configured to run.
 */
public final class MasterUtils {
  private MasterUtils() {}  // prevent instantiation

  /**
   * Creates all the masters and registers them to the master registry.
   *
   * @param registry the master registry
   * @param context master context
   */
  public static void createMasters(MasterRegistry registry, MasterContext context) {
    List> callables = new ArrayList<>();
    for (final MasterFactory factory : alluxio.master.ServiceUtils.getMasterServiceLoader()) {
      callables.add(() -> {
        if (factory.isEnabled()) {
          factory.create(registry, context);
        }
        return null;
      });
    }
    try {
      CommonUtils.invokeAll(callables, 10L * Constants.MINUTE_MS);
    } catch (Exception e) {
      throw new RuntimeException("Failed to start masters", e);
    }
  }

  /**
   * @param baseDir the base directory in which to store on-disk metadata
   * @return a block store factory of the configured type
   */
  public static BlockMetaStore.Factory getBlockStoreFactory(String baseDir) {
    MetastoreType type = Configuration.isSetByUser(PropertyKey.MASTER_BLOCK_METASTORE)
        ? Configuration.getEnum(PropertyKey.MASTER_BLOCK_METASTORE, MetastoreType.class) :
        Configuration.getEnum(PropertyKey.MASTER_METASTORE, MetastoreType.class);
    switch (type) {
      case HEAP:
        return HeapBlockMetaStore::new;
      case ROCKS:
        return () -> new RocksBlockMetaStore(baseDir);
      default:
        throw new IllegalStateException("Unknown metastore type: " + type);
    }
  }

  /**
   * @param baseDir the base directory in which to store on-disk metadata
   * @return an inode store factory of the configured type
   */
  public static InodeStore.Factory getInodeStoreFactory(String baseDir) {
    MetastoreType type = Configuration.isSetByUser(PropertyKey.MASTER_INODE_METASTORE)
        ? Configuration.getEnum(PropertyKey.MASTER_INODE_METASTORE, MetastoreType.class) :
        Configuration.getEnum(PropertyKey.MASTER_METASTORE, MetastoreType.class);
    switch (type) {
      case HEAP:
        return lockManager -> new HeapInodeStore();
      case ROCKS:
        if (Configuration.getInt(PropertyKey.MASTER_METASTORE_INODE_CACHE_MAX_SIZE) == 0) {
          return lockManager -> new RocksInodeStore(baseDir);
        } else {
          return lockManager -> new CachingInodeStore(new RocksInodeStore(baseDir), lockManager);
        }
      default:
        throw new IllegalStateException("Unknown metastore type: " + type);
    }
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy