當前位置: 首頁>>代碼示例>>Java>>正文


Java ServerRegionReplicaUtil類代碼示例

本文整理匯總了Java中org.apache.hadoop.hbase.util.ServerRegionReplicaUtil的典型用法代碼示例。如果您正苦於以下問題:Java ServerRegionReplicaUtil類的具體用法?Java ServerRegionReplicaUtil怎麽用?Java ServerRegionReplicaUtil使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


ServerRegionReplicaUtil類屬於org.apache.hadoop.hbase.util包,在下文中一共展示了ServerRegionReplicaUtil類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: addTableToMeta

import org.apache.hadoop.hbase.util.ServerRegionReplicaUtil; //導入依賴的package包/類
protected static List<HRegionInfo> addTableToMeta(final MasterProcedureEnv env,
    final HTableDescriptor hTableDescriptor,
    final List<HRegionInfo> regions) throws IOException {
  if (regions != null && regions.size() > 0) {
    ProcedureSyncWait.waitMetaRegions(env);

    // Add regions to META
    addRegionsToMeta(env, hTableDescriptor, regions);
    // Add replicas if needed
    List<HRegionInfo> newRegions = addReplicas(env, hTableDescriptor, regions);

    // Setup replication for region replicas if needed
    if (hTableDescriptor.getRegionReplication() > 1) {
      ServerRegionReplicaUtil.setupRegionReplicaReplication(env.getMasterConfiguration());
    }
    return newRegions;
  }
  return regions;
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:20,代碼來源:CreateTableProcedure.java

示例2: triggerFlushInPrimaryRegion

import org.apache.hadoop.hbase.util.ServerRegionReplicaUtil; //導入依賴的package包/類
/**
 * Trigger a flush in the primary region replica if this region is a secondary replica. Does not
 * block this thread. See RegionReplicaFlushHandler for details.
 */
void triggerFlushInPrimaryRegion(final HRegion region) {
  if (ServerRegionReplicaUtil.isDefaultReplica(region.getRegionInfo())) {
    return;
  }
  if (!ServerRegionReplicaUtil.isRegionReplicaReplicationEnabled(region.conf)
      || !ServerRegionReplicaUtil.isRegionReplicaWaitForPrimaryFlushEnabled(region.conf)) {
    region.setReadsEnabled(true);
    return;
  }

  region.setReadsEnabled(false); // disable reads before marking the region as opened.
  // RegionReplicaFlushHandler might reset this.

  // submit it to be handled by one of the handlers so that we do not block OpenRegionHandler
  this.service.submit(
      new RegionReplicaFlushHandler(this, clusterConnection, rpcRetryingCallerFactory,
          rpcControllerFactory, operationTimeout, region));
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:23,代碼來源:HRegionServer.java

示例3: beforeClass

import org.apache.hadoop.hbase.util.ServerRegionReplicaUtil; //導入依賴的package包/類
@BeforeClass
public static void beforeClass() throws Exception {
  Configuration conf = HTU.getConfiguration();
  conf.setFloat("hbase.regionserver.logroll.multiplier", 0.0003f);
  conf.setInt("replication.source.size.capacity", 10240);
  conf.setLong("replication.source.sleepforretries", 100);
  conf.setInt("hbase.regionserver.maxlogs", 10);
  conf.setLong("hbase.master.logcleaner.ttl", 10);
  conf.setInt("zookeeper.recovery.retry", 1);
  conf.setInt("zookeeper.recovery.retry.intervalmill", 10);
  conf.setBoolean(HConstants.REPLICATION_ENABLE_KEY, true);
  conf.setBoolean(ServerRegionReplicaUtil.REGION_REPLICA_REPLICATION_CONF_KEY, true);
  conf.setLong(HConstants.THREAD_WAKE_FREQUENCY, 100);
  conf.setInt("replication.stats.thread.period.seconds", 5);
  conf.setBoolean("hbase.tests.use.shortcircuit.reads", false);
  conf.setInt(HConstants.HBASE_CLIENT_RETRIES_NUMBER, 5); // less number of retries is needed
  conf.setInt("hbase.client.serverside.retries.multiplier", 1);

  HTU.startMiniCluster(NB_SERVERS);
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:21,代碼來源:TestRegionReplicaReplicationEndpoint.java

示例4: before

import org.apache.hadoop.hbase.util.ServerRegionReplicaUtil; //導入依賴的package包/類
@Before
public void before() throws Exception {
  Configuration conf = HTU.getConfiguration();
 // Up the handlers; this test needs more than usual.
  conf.setInt(HConstants.REGION_SERVER_HIGH_PRIORITY_HANDLER_COUNT, 10);
  conf.setBoolean(HConstants.REPLICATION_ENABLE_KEY, true);
  conf.setBoolean(ServerRegionReplicaUtil.REGION_REPLICA_REPLICATION_CONF_KEY, true);
  conf.setBoolean(ServerRegionReplicaUtil.REGION_REPLICA_WAIT_FOR_PRIMARY_FLUSH_CONF_KEY, true);
  conf.setInt("replication.stats.thread.period.seconds", 5);
  conf.setBoolean("hbase.tests.use.shortcircuit.reads", false);
  conf.setBoolean(HConstants.DISTRIBUTED_LOG_REPLAY_KEY, distributedLogReplay);

  HTU.startMiniCluster(NB_SERVERS);
  htd = HTU.createTableDescriptor(
    name.getMethodName().substring(0, name.getMethodName().length()-3));
  htd.setRegionReplication(3);
  HTU.getHBaseAdmin().createTable(htd);
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:19,代碼來源:TestRegionReplicaFailover.java

示例5: setConf

import org.apache.hadoop.hbase.util.ServerRegionReplicaUtil; //導入依賴的package包/類
@Override
public void setConf(Configuration conf) {
  conf.setIfUnset(
    String.format("%s.%s", TEST_NAME, LoadTestTool.OPT_REGION_REPLICATION),
    String.valueOf(DEFAULT_REGION_REPLICATION));

  conf.setIfUnset(
    String.format("%s.%s", TEST_NAME, LoadTestTool.OPT_COLUMN_FAMILIES),
    StringUtils.join(",", DEFAULT_COLUMN_FAMILIES));

  conf.setBoolean("hbase.table.sanity.checks", true);

  // enable async wal replication to region replicas for unit tests
  conf.setBoolean(ServerRegionReplicaUtil.REGION_REPLICA_REPLICATION_CONF_KEY, true);
  conf.setBoolean(HConstants.REPLICATION_ENABLE_KEY, true);

  conf.setLong(HConstants.HREGION_MEMSTORE_FLUSH_SIZE, 1024L * 1024 * 4); // flush every 4 MB
  conf.setInt("hbase.hstore.blockingStoreFiles", 100);

  super.setConf(conf);
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:22,代碼來源:IntegrationTestRegionReplicaReplication.java

示例6: triggerFlushInPrimaryRegion

import org.apache.hadoop.hbase.util.ServerRegionReplicaUtil; //導入依賴的package包/類
/**
 * Trigger a flush in the primary region replica if this region is a secondary replica. Does not
 * block this thread. See RegionReplicaFlushHandler for details.
 */
void triggerFlushInPrimaryRegion(final HRegion region) {
  if (ServerRegionReplicaUtil.isDefaultReplica(region.getRegionInfo())) {
    return;
  }
  if (!ServerRegionReplicaUtil.isRegionReplicaReplicationEnabled(region.conf) ||
      !ServerRegionReplicaUtil.isRegionReplicaWaitForPrimaryFlushEnabled(
        region.conf)) {
    region.setReadsEnabled(true);
    return;
  }

  region.setReadsEnabled(false); // disable reads before marking the region as opened.
  // RegionReplicaFlushHandler might reset this.

  // submit it to be handled by one of the handlers so that we do not block OpenRegionHandler
  if (this.executorService != null) {
    this.executorService.submit(new RegionReplicaFlushHandler(this, clusterConnection,
        rpcRetryingCallerFactory, rpcControllerFactory, operationTimeout, region));
  }
}
 
開發者ID:apache,項目名稱:hbase,代碼行數:25,代碼來源:HRegionServer.java

示例7: getStoreFiles

import org.apache.hadoop.hbase.util.ServerRegionReplicaUtil; //導入依賴的package包/類
/**
 * Returns the store files available for the family.
 * This methods performs the filtering based on the valid store files.
 * @param familyName Column Family Name
 * @return a set of {@link StoreFileInfo} for the specified family.
 */
public Collection<StoreFileInfo> getStoreFiles(final String familyName, final boolean validate)
    throws IOException {
  Path familyDir = getStoreDir(familyName);
  FileStatus[] files = FSUtils.listStatus(this.fs, familyDir);
  if (files == null) {
    if (LOG.isTraceEnabled()) {
      LOG.trace("No StoreFiles for: " + familyDir);
    }
    return null;
  }

  ArrayList<StoreFileInfo> storeFiles = new ArrayList<>(files.length);
  for (FileStatus status: files) {
    if (validate && !StoreFileInfo.isValid(status)) {
      LOG.warn("Invalid StoreFile: " + status.getPath());
      continue;
    }
    StoreFileInfo info = ServerRegionReplicaUtil.getStoreFileInfo(conf, fs, regionInfo,
      regionInfoForFs, familyName, status.getPath());
    storeFiles.add(info);

  }
  return storeFiles;
}
 
開發者ID:apache,項目名稱:hbase,代碼行數:31,代碼來源:HRegionFileSystem.java

示例8: beforeClass

import org.apache.hadoop.hbase.util.ServerRegionReplicaUtil; //導入依賴的package包/類
@BeforeClass
public static void beforeClass() throws Exception {
  Configuration conf = HTU.getConfiguration();
  conf.setFloat("hbase.regionserver.logroll.multiplier", 0.0003f);
  conf.setInt("replication.source.size.capacity", 10240);
  conf.setLong("replication.source.sleepforretries", 100);
  conf.setInt("hbase.regionserver.maxlogs", 10);
  conf.setLong("hbase.master.logcleaner.ttl", 10);
  conf.setInt("zookeeper.recovery.retry", 1);
  conf.setInt("zookeeper.recovery.retry.intervalmill", 10);
  conf.setBoolean(ServerRegionReplicaUtil.REGION_REPLICA_REPLICATION_CONF_KEY, true);
  conf.setLong(HConstants.THREAD_WAKE_FREQUENCY, 100);
  conf.setInt("replication.stats.thread.period.seconds", 5);
  conf.setBoolean("hbase.tests.use.shortcircuit.reads", false);
  conf.setInt(HConstants.HBASE_CLIENT_RETRIES_NUMBER, 5); // less number of retries is needed
  conf.setInt(HConstants.HBASE_CLIENT_SERVERSIDE_RETRIES_MULTIPLIER, 1);

  HTU.startMiniCluster(NB_SERVERS);
}
 
開發者ID:apache,項目名稱:hbase,代碼行數:20,代碼來源:TestRegionReplicaReplicationEndpoint.java

示例9: before

import org.apache.hadoop.hbase.util.ServerRegionReplicaUtil; //導入依賴的package包/類
@Before
public void before() throws Exception {
  Configuration conf = HTU.getConfiguration();
 // Up the handlers; this test needs more than usual.
  conf.setInt(HConstants.REGION_SERVER_HIGH_PRIORITY_HANDLER_COUNT, 10);
  conf.setBoolean(ServerRegionReplicaUtil.REGION_REPLICA_REPLICATION_CONF_KEY, true);
  conf.setBoolean(ServerRegionReplicaUtil.REGION_REPLICA_WAIT_FOR_PRIMARY_FLUSH_CONF_KEY, true);
  conf.setInt("replication.stats.thread.period.seconds", 5);
  conf.setBoolean("hbase.tests.use.shortcircuit.reads", false);

  HTU.startMiniCluster(NB_SERVERS);
  htd = HTU.createTableDescriptor(
    name.getMethodName().substring(0, name.getMethodName().length()-3));
  htd.setRegionReplication(3);
  HTU.getAdmin().createTable(htd);
}
 
開發者ID:apache,項目名稱:hbase,代碼行數:17,代碼來源:TestRegionReplicaFailover.java

示例10: setConf

import org.apache.hadoop.hbase.util.ServerRegionReplicaUtil; //導入依賴的package包/類
@Override
public void setConf(Configuration conf) {
  conf.setIfUnset(
    String.format("%s.%s", TEST_NAME, LoadTestTool.OPT_REGION_REPLICATION),
    String.valueOf(DEFAULT_REGION_REPLICATION));

  conf.setIfUnset(
    String.format("%s.%s", TEST_NAME, LoadTestTool.OPT_COLUMN_FAMILIES),
    StringUtils.join(",", DEFAULT_COLUMN_FAMILIES));

  conf.setBoolean("hbase.table.sanity.checks", true);

  // enable async wal replication to region replicas for unit tests
  conf.setBoolean(ServerRegionReplicaUtil.REGION_REPLICA_REPLICATION_CONF_KEY, true);

  conf.setLong(HConstants.HREGION_MEMSTORE_FLUSH_SIZE, 1024L * 1024 * 4); // flush every 4 MB
  conf.setInt("hbase.hstore.blockingStoreFiles", 100);

  super.setConf(conf);
}
 
開發者ID:apache,項目名稱:hbase,代碼行數:21,代碼來源:IntegrationTestRegionReplicaReplication.java

示例11: updateReplicaColumnsIfNeeded

import org.apache.hadoop.hbase.util.ServerRegionReplicaUtil; //導入依賴的package包/類
/**
 * update replica column families if necessary.
 * @param env MasterProcedureEnv
 * @throws IOException
 */
private void updateReplicaColumnsIfNeeded(
  final MasterProcedureEnv env,
  final HTableDescriptor oldHTableDescriptor,
  final HTableDescriptor newHTableDescriptor) throws IOException {
  final int oldReplicaCount = oldHTableDescriptor.getRegionReplication();
  final int newReplicaCount = newHTableDescriptor.getRegionReplication();

  if (newReplicaCount < oldReplicaCount) {
    Set<byte[]> tableRows = new HashSet<byte[]>();
    Connection connection = env.getMasterServices().getConnection();
    Scan scan = MetaTableAccessor.getScanForTableName(getTableName());
    scan.addColumn(HConstants.CATALOG_FAMILY, HConstants.REGIONINFO_QUALIFIER);

    try (Table metaTable = connection.getTable(TableName.META_TABLE_NAME)) {
      ResultScanner resScanner = metaTable.getScanner(scan);
      for (Result result : resScanner) {
        tableRows.add(result.getRow());
      }
      MetaTableAccessor.removeRegionReplicasFromMeta(
        tableRows,
        newReplicaCount,
        oldReplicaCount - newReplicaCount,
        connection);
    }
  }

  // Setup replication for region replicas if needed
  if (newReplicaCount > 1 && oldReplicaCount <= 1) {
    ServerRegionReplicaUtil.setupRegionReplicaReplication(env.getMasterConfiguration());
  }
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:37,代碼來源:ModifyTableProcedure.java

示例12: HRegionFileSystem

import org.apache.hadoop.hbase.util.ServerRegionReplicaUtil; //導入依賴的package包/類
/**
 * Create a view to the on-disk region
 *
 * @param conf       the {@link Configuration} to use
 * @param fs         {@link FileSystem} that contains the region
 * @param tableDir   {@link Path} to where the table is being stored
 * @param regionInfo {@link HRegionInfo} for region
 */
HRegionFileSystem(final Configuration conf, final FileSystem fs, final Path tableDir,
    final HRegionInfo regionInfo) {
  this.fs = fs;
  this.conf = conf;
  this.tableDir = tableDir;
  this.regionInfo = regionInfo;
  this.regionInfoForFs = ServerRegionReplicaUtil.getRegionInfoForFs(regionInfo);
  this.hdfsClientRetriesNumber =
      conf.getInt("hdfs.client.retries.number", DEFAULT_HDFS_CLIENT_RETRIES_NUMBER);
  this.baseSleepBeforeRetries =
      conf.getInt("hdfs.client.sleep.before.retries", DEFAULT_BASE_SLEEP_BEFORE_RETRIES);
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:21,代碼來源:HRegionFileSystem.java

示例13: getStoreFiles

import org.apache.hadoop.hbase.util.ServerRegionReplicaUtil; //導入依賴的package包/類
/**
 * Returns the store files available for the family. This methods performs the filtering based on
 * the valid store files.
 *
 * @param familyName Column Family Name
 * @return a set of {@link StoreFileInfo} for the specified family.
 */
public Collection<StoreFileInfo> getStoreFiles(final String familyName, final boolean validate)
    throws IOException {
  Path familyDir = getStoreDir(familyName);
  // FileStatus[] files = FSUtils.listStatus(this.fs, familyDir);
  FileStatus[] files = FSUtils.listStatus(this.fs, familyDir, new PathFilter() {
    @Override public boolean accept(Path path) {
      String name = path.getName();
      if (name.endsWith(IndexConstants.REGION_INDEX_DIR_NAME) || name
          .endsWith(LMDIndexConstants.BUCKET_FILE_SUFFIX) || name
          .endsWith(LMDIndexConstants.DATA_FILE_SUFFIX)) return false;
      return true;
    }
  });
  if (files == null) {
    LOG.debug("No StoreFiles for: " + familyDir);
    return null;
  }

  ArrayList<StoreFileInfo> storeFiles = new ArrayList<StoreFileInfo>(files.length);
  for (FileStatus status : files) {
    if (validate && !StoreFileInfo.isValid(status)) {
      LOG.warn("Invalid StoreFile: " + status.getPath());
      continue;
    }
    StoreFileInfo info = ServerRegionReplicaUtil
        .getStoreFileInfo(conf, fs, regionInfo, regionInfoForFs, familyName, status.getPath());
    storeFiles.add(info);
  }
  return storeFiles;
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:38,代碼來源:HRegionFileSystem.java

示例14: getStoreFileInfo

import org.apache.hadoop.hbase.util.ServerRegionReplicaUtil; //導入依賴的package包/類
/**
 * Return the store file information of the specified family/file.
 *
 * @param familyName Column Family Name
 * @param fileName   File Name
 * @return The {@link StoreFileInfo} for the specified family/file
 */
StoreFileInfo getStoreFileInfo(final String familyName, final String fileName)
    throws IOException {
  Path familyDir = getStoreDir(familyName);
  return ServerRegionReplicaUtil
      .getStoreFileInfo(conf, fs, regionInfo, regionInfoForFs, familyName,
          new Path(familyDir, fileName));
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:15,代碼來源:HRegionFileSystem.java

示例15: beforeClass

import org.apache.hadoop.hbase.util.ServerRegionReplicaUtil; //導入依賴的package包/類
@BeforeClass
public static void beforeClass() throws Exception {
  Configuration conf = HTU.getConfiguration();
  conf.setBoolean(HConstants.REPLICATION_ENABLE_KEY, true);
  conf.setBoolean(ServerRegionReplicaUtil.REGION_REPLICA_REPLICATION_CONF_KEY, true);
  conf.setBoolean(ServerRegionReplicaUtil.REGION_REPLICA_WAIT_FOR_PRIMARY_FLUSH_CONF_KEY, false);

  // install WALObserver coprocessor for tests
  String walCoprocs = HTU.getConfiguration().get(CoprocessorHost.WAL_COPROCESSOR_CONF_KEY);
  if (walCoprocs == null) {
    walCoprocs = WALEditCopro.class.getName();
  } else {
    walCoprocs += "," + WALEditCopro.class.getName();
  }
  HTU.getConfiguration().set(CoprocessorHost.WAL_COPROCESSOR_CONF_KEY,
    walCoprocs);
  HTU.startMiniCluster(NB_SERVERS);

  // Create table then get the single region for our new table.
  HTableDescriptor htd = HTU.createTableDescriptor(tableName.toString());
  table = HTU.createTable(htd, new byte[][]{f}, HTU.getConfiguration());

  hriPrimary = table.getRegionLocation(row, false).getRegionInfo();

  // mock a secondary region info to open
  hriSecondary = new HRegionInfo(hriPrimary.getTable(), hriPrimary.getStartKey(),
      hriPrimary.getEndKey(), hriPrimary.isSplit(), hriPrimary.getRegionId(), 1);

  // No master
  TestRegionServerNoMaster.stopMasterAndAssignMeta(HTU);
  rs0 = HTU.getMiniHBaseCluster().getRegionServer(0);
  rs1 = HTU.getMiniHBaseCluster().getRegionServer(1);
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:34,代碼來源:TestRegionReplicaReplicationEndpointNoMaster.java


注:本文中的org.apache.hadoop.hbase.util.ServerRegionReplicaUtil類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。