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


Java Range.isInRanges方法代码示例

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


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

示例1: cleanup

import org.apache.cassandra.dht.Range; //导入方法依赖的package包/类
@Override
public SSTableIdentityIterator cleanup(SSTableIdentityIterator row)
{
    if (Range.isInRanges(row.getKey().getToken(), ranges))
        return row;

    cfs.invalidateCachedRow(row.getKey());

    if (indexedColumnsInRow != null)
        indexedColumnsInRow.clear();

    while (row.hasNext())
    {
        OnDiskAtom column = row.next();

        if (column instanceof Cell && cfs.indexManager.indexes((Cell) column))
        {
            if (indexedColumnsInRow == null)
                indexedColumnsInRow = new ArrayList<>();

            indexedColumnsInRow.add((Cell) column);
        }
    }

    if (indexedColumnsInRow != null && !indexedColumnsInRow.isEmpty())
    {
        // acquire memtable lock here because secondary index deletion may cause a race. See CASSANDRA-3712
        try (OpOrder.Group opGroup = cfs.keyspace.writeOrder.start())
        {
            cfs.indexManager.deleteFromIndexes(row.getKey(), indexedColumnsInRow, opGroup);
        }
    }
    return null;
}
 
开发者ID:vcostet,项目名称:cassandra-kmean,代码行数:35,代码来源:CompactionManager.java

示例2: cleanupCache

import org.apache.cassandra.dht.Range; //导入方法依赖的package包/类
public void cleanupCache()
{
    Collection<Range<Token>> ranges = StorageService.instance.getLocalRanges(keyspace.getName());

    for (RowCacheKey key : CacheService.instance.rowCache.getKeySet())
    {
        DecoratedKey dk = partitioner.decorateKey(ByteBuffer.wrap(key.key));
        if (key.cfId == metadata.cfId && !Range.isInRanges(dk.token, ranges))
            invalidateCachedRow(dk);
    }
}
 
开发者ID:pgaref,项目名称:ACaZoo,代码行数:12,代码来源:ColumnFamilyStore.java

示例3: cleanup

import org.apache.cassandra.dht.Range; //导入方法依赖的package包/类
@Override
public UnfilteredRowIterator cleanup(UnfilteredRowIterator partition)
{
    if (Range.isInRanges(partition.partitionKey().getToken(), ranges))
        return partition;

    cfs.invalidateCachedPartition(partition.partitionKey());

    cfs.indexManager.deletePartition(partition, nowInSec);
    return null;
}
 
开发者ID:scylladb,项目名称:scylla-tools-java,代码行数:12,代码来源:CompactionManager.java

示例4: doAntiCompaction

import org.apache.cassandra.dht.Range; //导入方法依赖的package包/类
/**
 * Splits up an sstable into two new sstables. The first of the new tables will store repaired ranges, the second
 * will store the non-repaired ranges. Once anticompation is completed, the original sstable is marked as compacted
 * and subsequently deleted.
 * @param cfs
 * @param repairedSSTables
 * @param ranges Repaired ranges to be placed into one of the new sstables. The repaired table will be tracked via
 * the {@link org.apache.cassandra.io.sstable.metadata.StatsMetadata#repairedAt} field.
 */
private Collection<SSTableReader> doAntiCompaction(ColumnFamilyStore cfs, Collection<Range<Token>> ranges, Collection<SSTableReader> repairedSSTables, long repairedAt)
{
    List<SSTableReader> anticompactedSSTables = new ArrayList<>();
    int repairedKeyCount = 0;
    int unrepairedKeyCount = 0;
    logger.info("Performing anticompaction on {} sstables", repairedSSTables.size());
    // iterate over sstables to check if the repaired / unrepaired ranges intersect them.
    for (SSTableReader sstable : repairedSSTables)
    {
        // check that compaction hasn't stolen any sstables used in previous repair sessions
        // if we need to skip the anticompaction, it will be carried out by the next repair
        if (!new File(sstable.getFilename()).exists())
        {
            logger.info("Skipping anticompaction for {}, required sstable was compacted and is no longer available.", sstable);
            continue;
        }

        logger.info("Anticompacting {}", sstable);
        Set<SSTableReader> sstableAsSet = new HashSet<>();
        sstableAsSet.add(sstable);

        File destination = cfs.directories.getWriteableLocationAsFile(cfs.getExpectedCompactedFileSize(sstableAsSet, OperationType.ANTICOMPACTION));
        SSTableRewriter repairedSSTableWriter = new SSTableRewriter(cfs, sstableAsSet, sstable.maxDataAge, false);
        SSTableRewriter unRepairedSSTableWriter = new SSTableRewriter(cfs, sstableAsSet, sstable.maxDataAge, false);

        try (AbstractCompactionStrategy.ScannerList scanners = cfs.getCompactionStrategy().getScanners(new HashSet<>(Collections.singleton(sstable)));
             CompactionController controller = new CompactionController(cfs, sstableAsSet, CFMetaData.DEFAULT_GC_GRACE_SECONDS))
        {
            int expectedBloomFilterSize = Math.max(cfs.metadata.getMinIndexInterval(), (int)sstable.estimatedKeys());
            repairedSSTableWriter.switchWriter(CompactionManager.createWriter(cfs, destination, expectedBloomFilterSize, repairedAt, sstable));
            unRepairedSSTableWriter.switchWriter(CompactionManager.createWriter(cfs, destination, expectedBloomFilterSize, ActiveRepairService.UNREPAIRED_SSTABLE, sstable));

            CompactionIterable ci = new CompactionIterable(OperationType.ANTICOMPACTION, scanners.scanners, controller);
            Iterator<AbstractCompactedRow> iter = ci.iterator();
            while(iter.hasNext())
            {
                AbstractCompactedRow row = iter.next();
                // if current range from sstable is repaired, save it into the new repaired sstable
                if (Range.isInRanges(row.key.getToken(), ranges))
                {
                    repairedSSTableWriter.append(row);
                    repairedKeyCount++;
                }
                // otherwise save into the new 'non-repaired' table
                else
                {
                    unRepairedSSTableWriter.append(row);
                    unrepairedKeyCount++;
                }
            }
            anticompactedSSTables.addAll(repairedSSTableWriter.finish(repairedAt));
            anticompactedSSTables.addAll(unRepairedSSTableWriter.finish(ActiveRepairService.UNREPAIRED_SSTABLE));
            cfs.getDataTracker().markCompactedSSTablesReplaced(sstableAsSet, anticompactedSSTables, OperationType.ANTICOMPACTION);
        }
        catch (Throwable e)
        {
            JVMStabilityInspector.inspectThrowable(e);
            logger.error("Error anticompacting " + sstable, e);
            repairedSSTableWriter.abort();
            unRepairedSSTableWriter.abort();
        }
    }
    String format = "Repaired {} keys of {} for {}/{}";
    logger.debug(format, repairedKeyCount, (repairedKeyCount + unrepairedKeyCount), cfs.keyspace, cfs.getColumnFamilyName());
    String format2 = "Anticompaction completed successfully, anticompacted from {} to {} sstable(s).";
    logger.info(format2, repairedSSTables.size(), anticompactedSSTables.size());

    return anticompactedSSTables;
}
 
开发者ID:vcostet,项目名称:cassandra-kmean,代码行数:79,代码来源:CompactionManager.java

示例5: cleanup

import org.apache.cassandra.dht.Range; //导入方法依赖的package包/类
@Override
public SSTableIdentityIterator cleanup(SSTableIdentityIterator row)
{
    if (Range.isInRanges(row.getKey().token, ranges))
        return row;

    cfs.invalidateCachedRow(row.getKey());

    if (indexedColumnsInRow != null)
        indexedColumnsInRow.clear();

    while (row.hasNext())
    {
        OnDiskAtom column = row.next();
        if (column instanceof CounterColumn)
            renewer.maybeRenew((CounterColumn) column);

        if (column instanceof Column && cfs.indexManager.indexes((Column) column))
        {
            if (indexedColumnsInRow == null)
                indexedColumnsInRow = new ArrayList<>();

            indexedColumnsInRow.add((Column) column);
        }
    }

    if (indexedColumnsInRow != null && !indexedColumnsInRow.isEmpty())
    {
        // acquire memtable lock here because secondary index deletion may cause a race. See CASSANDRA-3712
        Keyspace.switchLock.readLock().lock();
        try
        {
            cfs.indexManager.deleteFromIndexes(row.getKey(), indexedColumnsInRow);
        }
        finally
        {
            Keyspace.switchLock.readLock().unlock();
        }
    }
    return null;
}
 
开发者ID:pgaref,项目名称:ACaZoo,代码行数:42,代码来源:CompactionManager.java


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