当前位置: 首页>>代码示例>>Java>>正文


Java CellUtil.updateLatestStamp方法代码示例

本文整理汇总了Java中org.apache.hadoop.hbase.CellUtil.updateLatestStamp方法的典型用法代码示例。如果您正苦于以下问题:Java CellUtil.updateLatestStamp方法的具体用法?Java CellUtil.updateLatestStamp怎么用?Java CellUtil.updateLatestStamp使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在org.apache.hadoop.hbase.CellUtil的用法示例。


在下文中一共展示了CellUtil.updateLatestStamp方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: updateDeleteLatestVersionTimeStamp

import org.apache.hadoop.hbase.CellUtil; //导入方法依赖的package包/类
void updateDeleteLatestVersionTimeStamp(Cell cell, Get get, int count, byte[] byteNow)
    throws IOException {
  List<Cell> result = get(get, false);

  if (result.size() < count) {
    // Nothing to delete
    CellUtil.updateLatestStamp(cell, byteNow, 0);
    return;
  }
  if (result.size() > count) {
    throw new RuntimeException("Unexpected size: " + result.size());
  }
  Cell getCell = result.get(count - 1);
  CellUtil.setTimestamp(cell, getCell.getTimestamp());
}
 
开发者ID:fengchen8086,项目名称:ditb,代码行数:16,代码来源:HRegion.java

示例2: prePrepareTimeStampForDeleteVersion

import org.apache.hadoop.hbase.CellUtil; //导入方法依赖的package包/类
@Override
public void prePrepareTimeStampForDeleteVersion(
    ObserverContext<RegionCoprocessorEnvironment> ctx, Mutation delete, Cell cell,
    byte[] byteNow, Get get) throws IOException {
  // Nothing to do if we are not filtering by visibility
  if (!authorizationEnabled) {
    return;
  }

  CellVisibility cellVisibility = null;
  try {
    cellVisibility = delete.getCellVisibility();
  } catch (DeserializationException de) {
    throw new IOException("Invalid cell visibility specified " + delete, de);
  }
  // The check for checkForReservedVisibilityTagPresence happens in preBatchMutate happens.
  // It happens for every mutation and that would be enough.
  List<Tag> visibilityTags = new ArrayList<Tag>();
  if (cellVisibility != null) {
    String labelsExp = cellVisibility.getExpression();
    try {
      visibilityTags = this.visibilityLabelService.createVisibilityExpTags(labelsExp, false,
          false);
    } catch (InvalidLabelException e) {
      throw new IOException("Invalid cell visibility specified " + labelsExp, e);
    }
  }
  get.setFilter(new DeleteVersionVisibilityExpressionFilter(visibilityTags,
      VisibilityConstants.SORTED_ORDINAL_SERIALIZATION_FORMAT));
  List<Cell> result = ctx.getEnvironment().getRegion().get(get, false);

  if (result.size() < get.getMaxVersions()) {
    // Nothing to delete
    CellUtil.updateLatestStamp(cell, Long.MIN_VALUE);
    return;
  }
  if (result.size() > get.getMaxVersions()) {
    throw new RuntimeException("Unexpected size: " + result.size()
        + ". Results more than the max versions obtained.");
  }
  Cell getCell = result.get(get.getMaxVersions() - 1);
  CellUtil.setTimestamp(cell, getCell.getTimestamp());

  // We are bypassing here because in the HRegion.updateDeleteLatestVersionTimeStamp we would
  // update with the current timestamp after again doing a get. As the hook as already determined
  // the needed timestamp we need to bypass here.
  // TODO : See if HRegion.updateDeleteLatestVersionTimeStamp() could be
  // called only if the hook is not called.
  ctx.bypass();
}
 
开发者ID:fengchen8086,项目名称:ditb,代码行数:51,代码来源:VisibilityController.java


注:本文中的org.apache.hadoop.hbase.CellUtil.updateLatestStamp方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。