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


Java ReadCommand类代码示例

本文整理汇总了Java中org.apache.cassandra.db.ReadCommand的典型用法代码示例。如果您正苦于以下问题:Java ReadCommand类的具体用法?Java ReadCommand怎么用?Java ReadCommand使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。


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

示例1: postProcess

import org.apache.cassandra.db.ReadCommand; //导入依赖的package包/类
/**
 * Post processes in the coordinator node the results of a distributed
 * search. Gets the k globally best results from all the k best node-local
 * results.
 *
 * @param partitions
 *            the node results iterator
 * @param command
 *            the read command
 * @return the k globally best results
 */
public PartitionIterator postProcess(PartitionIterator partitions, ReadCommand command) {

	// Search search = search(command);
	//
	// // Skip if search does not require full scan
	// if (search.requiresFullScan()) {
	//
	// List<Pair<DecoratedKey, SimpleRowIterator>> collectedRows =
	// collect(partitions);
	//
	// Query query = search.query(schema);
	// Sort sort = sort(search);
	// int limit = command.limits().count();
	//
	// // Skip if search is not top-k TODO: Skip if only one partitioner
	// // range is involved
	// if (search.isTopK()) {
	// return process(query, sort, limit, collectedRows);
	// }
	// }
	return partitions;
}
 
开发者ID:jmiddleton,项目名称:cassandra-fhir-index,代码行数:34,代码来源:FhirIndexService.java

示例2: query

import org.apache.cassandra.db.ReadCommand; //导入依赖的package包/类
/**
 * Returns the Lucene {@link Query} represented by the specified
 * {@link Search} and key filter.
 *
 * @param expression
 *            the expression
 * @param command
 *            the command
 * @return a Lucene {@link Query}
 */
private Query query(String expression, ReadCommand command) {
	try {
		QueryParser queryParser = new QueryParser("query", this.indexOptions.search.defaultAnalyzer);
		queryParser.setDateResolution(Resolution.SECOND);
		Query searchQuery = queryParser.parse(expression);
		
		return searchQuery;
	} catch (ParseException e) {
		// TODO Auto-generated catch block
		throw new FhirIndexException(e);
	}

	// TODO: mejorar las busquedas por tipo
	// Optional<Query> maybeKeyRangeQuery = query(command);
	// if (maybeKeyRangeQuery.isPresent()) {
	// BooleanQuery.Builder builder = new BooleanQuery.Builder();
	// builder.add(maybeKeyRangeQuery.get(), FILTER);
	// builder.add(searchQuery, MUST);
	// return builder.build();
	// } else {
	// }
}
 
开发者ID:jmiddleton,项目名称:cassandra-fhir-index,代码行数:33,代码来源:FhirIndexService.java

示例3: makeRequests

import org.apache.cassandra.db.ReadCommand; //导入依赖的package包/类
private void makeRequests(ReadCommand readCommand, Iterable<InetAddress> endpoints)
{
    MessageOut<ReadCommand> message = null;
    boolean hasLocalEndpoint = false;

    for (InetAddress endpoint : endpoints)
    {
        if (isLocalRequest(endpoint))
        {
            hasLocalEndpoint = true;
            continue;
        }

        logger.trace("reading {} from {}", readCommand.isDigestQuery() ? "digest" : "data", endpoint);
        if (message == null)
            message = readCommand.createMessage();
        MessagingService.instance().sendRR(message, endpoint, handler);
    }

    // We delay the local (potentially blocking) read till the end to avoid stalling remote requests.
    if (hasLocalEndpoint)
    {
        logger.trace("reading {} locally", readCommand.isDigestQuery() ? "digest" : "data");
        StageManager.getStage(Stage.READ).maybeExecuteImmediately(new LocalReadRunnable(command, handler));
    }
}
 
开发者ID:vcostet,项目名称:cassandra-kmean,代码行数:27,代码来源:AbstractReadExecutor.java

示例4: maybeTryAdditionalReplicas

import org.apache.cassandra.db.ReadCommand; //导入依赖的package包/类
public void maybeTryAdditionalReplicas()
{
    // no latency information, or we're overloaded
    if (cfs.sampleLatencyNanos > TimeUnit.MILLISECONDS.toNanos(command.getTimeout()))
        return;

    if (!handler.await(cfs.sampleLatencyNanos, TimeUnit.NANOSECONDS))
    {
        // Could be waiting on the data, or on enough digests.
        ReadCommand retryCommand = command;
        if (resolver.getData() != null)
            retryCommand = command.copy().setIsDigestQuery(true);

        InetAddress extraReplica = Iterables.getLast(targetReplicas);
        logger.trace("speculating read retry on {}", extraReplica);
        MessagingService.instance().sendRR(retryCommand.createMessage(), extraReplica, handler);
        speculated = true;

        cfs.metric.speculativeRetries.inc();
    }
}
 
开发者ID:vcostet,项目名称:cassandra-kmean,代码行数:22,代码来源:AbstractReadExecutor.java

示例5: makeDigestRequests

import org.apache.cassandra.db.ReadCommand; //导入依赖的package包/类
protected void makeDigestRequests(Iterable<InetAddress> endpoints)
{
    ReadCommand digestCommand = command.copy();
    digestCommand.setDigestQuery(true);
    MessageOut<?> message = digestCommand.createMessage();
    for (InetAddress endpoint : endpoints)
    {
        if (isLocalRequest(endpoint))
        {
            logger.trace("reading digest locally");
            StageManager.getStage(Stage.READ).execute(new LocalReadRunnable(digestCommand, handler));
        }
        else
        {
            logger.trace("reading digest from {}", endpoint);
            MessagingService.instance().sendRR(message, endpoint, handler);
        }
    }
}
 
开发者ID:pgaref,项目名称:ACaZoo,代码行数:20,代码来源:AbstractReadExecutor.java

示例6: maybeTryAdditionalReplicas

import org.apache.cassandra.db.ReadCommand; //导入依赖的package包/类
public void maybeTryAdditionalReplicas()
{
    // no latency information, or we're overloaded
    if (cfs.sampleLatencyNanos > TimeUnit.MILLISECONDS.toNanos(command.getTimeout()))
        return;

    if (!handler.await(cfs.sampleLatencyNanos, TimeUnit.NANOSECONDS))
    {
        // Could be waiting on the data, or on enough digests.
        ReadCommand retryCommand = command;
        if (resolver.getData() != null)
        {
            retryCommand = command.copy();
            retryCommand.setDigestQuery(true);
        }

        InetAddress extraReplica = Iterables.getLast(targetReplicas);
        logger.trace("speculating read retry on {}", extraReplica);
        MessagingService.instance().sendRR(retryCommand.createMessage(), extraReplica, handler);
        speculated = true;

        cfs.metric.speculativeRetries.inc();
    }
}
 
开发者ID:pgaref,项目名称:ACaZoo,代码行数:25,代码来源:AbstractReadExecutor.java

示例7: retryDummyRead

import org.apache.cassandra.db.ReadCommand; //导入依赖的package包/类
private void retryDummyRead(String ks, String cf) throws PermanentBackendException {

        final long limit = System.currentTimeMillis() + (60L * 1000L);

        while (System.currentTimeMillis() < limit) {
            try {
                SortedSet<ByteBuffer> ss = new TreeSet<ByteBuffer>();
                ss.add(ByteBufferUtil.zeroByteBuffer(1));
                NamesQueryFilter nqf = new NamesQueryFilter(ss);
                SliceByNamesReadCommand cmd = new SliceByNamesReadCommand(ks, ByteBufferUtil.zeroByteBuffer(1), cf, 1L, nqf);
                StorageProxy.read(ImmutableList.<ReadCommand> of(cmd), ConsistencyLevel.QUORUM);
                log.info("Read on CF {} in KS {} succeeded", cf, ks);
                return;
            } catch (Throwable t) {
                log.warn("Failed to read CF {} in KS {} following creation", cf, ks, t);
            }

            try {
                Thread.sleep(1000L);
            } catch (InterruptedException e) {
                throw new PermanentBackendException(e);
            }
        }

        throw new PermanentBackendException("Timed out while attempting to read CF " + cf + " in KS " + ks + " following creation");
    }
 
开发者ID:graben1437,项目名称:titan0.5.4-hbase1.1.1-custom,代码行数:27,代码来源:CassandraEmbeddedStoreManager.java

示例8: AbstractReadExecutor

import org.apache.cassandra.db.ReadCommand; //导入依赖的package包/类
AbstractReadExecutor(Keyspace keyspace, ReadCommand command, ConsistencyLevel consistencyLevel, List<InetAddress> targetReplicas)
{
    this.command = command;
    this.targetReplicas = targetReplicas;
    this.handler = new ReadCallback(new DigestResolver(keyspace, command, consistencyLevel, targetReplicas.size()), consistencyLevel, command, targetReplicas);
    this.traceState = Tracing.instance.get();

    // Set the digest version (if we request some digests). This is the smallest version amongst all our target replicas since new nodes
    // knows how to produce older digest but the reverse is not true.
    // TODO: we need this when talking with pre-3.0 nodes. So if we preserve the digest format moving forward, we can get rid of this once
    // we stop being compatible with pre-3.0 nodes.
    int digestVersion = MessagingService.current_version;
    for (InetAddress replica : targetReplicas)
        digestVersion = Math.min(digestVersion, MessagingService.instance().getVersion(replica));
    command.setDigestVersion(digestVersion);
}
 
开发者ID:scylladb,项目名称:scylla-tools-java,代码行数:17,代码来源:AbstractReadExecutor.java

示例9: makeRequests

import org.apache.cassandra.db.ReadCommand; //导入依赖的package包/类
private void makeRequests(ReadCommand readCommand, Iterable<InetAddress> endpoints)
{
    boolean hasLocalEndpoint = false;

    for (InetAddress endpoint : endpoints)
    {
        if (StorageProxy.canDoLocalRequest(endpoint))
        {
            hasLocalEndpoint = true;
            continue;
        }

        if (traceState != null)
            traceState.trace("reading {} from {}", readCommand.isDigestQuery() ? "digest" : "data", endpoint);
        logger.trace("reading {} from {}", readCommand.isDigestQuery() ? "digest" : "data", endpoint);
        MessageOut<ReadCommand> message = readCommand.createMessage(MessagingService.instance().getVersion(endpoint));
        MessagingService.instance().sendRRWithFailure(message, endpoint, handler);
    }

    // We delay the local (potentially blocking) read till the end to avoid stalling remote requests.
    if (hasLocalEndpoint)
    {
        logger.trace("reading {} locally", readCommand.isDigestQuery() ? "digest" : "data");
        StageManager.getStage(Stage.READ).maybeExecuteImmediately(new LocalReadRunnable(command, handler));
    }
}
 
开发者ID:scylladb,项目名称:scylla-tools-java,代码行数:27,代码来源:AbstractReadExecutor.java

示例10: maybeTryAdditionalReplicas

import org.apache.cassandra.db.ReadCommand; //导入依赖的package包/类
public void maybeTryAdditionalReplicas()
{
    // no latency information, or we're overloaded
    if (cfs.sampleLatencyNanos > TimeUnit.MILLISECONDS.toNanos(command.getTimeout()))
        return;

    if (!handler.await(cfs.sampleLatencyNanos, TimeUnit.NANOSECONDS))
    {
        // Could be waiting on the data, or on enough digests.
        ReadCommand retryCommand = command;
        if (handler.resolver.isDataPresent())
            retryCommand = command.copy().setIsDigestQuery(true);

        InetAddress extraReplica = Iterables.getLast(targetReplicas);
        if (traceState != null)
            traceState.trace("speculating read retry on {}", extraReplica);
        logger.trace("speculating read retry on {}", extraReplica);
        int version = MessagingService.instance().getVersion(extraReplica);
        MessagingService.instance().sendRRWithFailure(retryCommand.createMessage(version), extraReplica, handler);
        speculated = true;

        cfs.metric.speculativeRetries.inc();
    }
}
 
开发者ID:scylladb,项目名称:scylla-tools-java,代码行数:25,代码来源:AbstractReadExecutor.java

示例11: getSliceTravelCommands

import org.apache.cassandra.db.ReadCommand; //导入依赖的package包/类
private List<ReadCommand> getSliceTravelCommands(QueryOptions options, long now, int step) throws RequestValidationException
{
	List<ReadCommand> commands = new ArrayList<>();

	Collection<ByteBuffer> keys = getKeys(options, step);
    //if (keys.isEmpty()) // in case of IN () for (the last column of) the partition key.
    
	IDiskAtomFilter filter = makeFilter(options, step);
    if (filter == null)
        return null;

    if (keys.isEmpty()){
    	//if we do not have keys yet, just create a Read Command with empty key.
    	ByteBuffer empty = ByteBuffer.wrap("EMPTY".getBytes());
    	//logger.info("@daidong debug: create read command with empty key ");
    	commands.add(ReadCommand.create(keyspace(), ByteBufferUtil.clone(empty), columnFamily(), now, filter.cloneShallow()));
    } else {
    	for (ByteBuffer key : keys)
    	{
    		QueryProcessor.validateKey(key);
    		//logger.info("@daidong debug: create read command with keys " + key.toString());
    		commands.add(ReadCommand.create(keyspace(), ByteBufferUtil.clone(key), columnFamily(), now, filter.cloneShallow()));
    	}
    }
    return commands;
}
 
开发者ID:daidong,项目名称:GraphTrek,代码行数:27,代码来源:TravelStatement.java

示例12: remoteStorageQuery

import org.apache.cassandra.db.ReadCommand; //导入依赖的package包/类
public static ColumnFamily remoteStorageQuery(String target, String dataTag){
	try {
		List<ReadCommand> command = new ArrayList<ReadCommand>();
		command.add(new SliceFromReadCommand(
				Metadata.MetaData_KS,
				ByteBufferUtil.bytes(target), 
				new QueryPath(Metadata.MetadataLog_CF),
				Column.decomposeName(String.valueOf(0) , "", dataTag, "value"),
				Column.decomposeName(String.valueOf(Long.MAX_VALUE) , "", dataTag, "value"),
				false,
				Integer.MAX_VALUE));

		List<Row> rows = StorageProxy.read(command, ConsistencyLevel.ANY);
		return rows.get(0).cf;
		 
	} catch (Exception e) {
		return null;
	}
}
 
开发者ID:dprguiuc,项目名称:Cassandra-Wasef,代码行数:20,代码来源:MetadataLog.java

示例13: remoteStorageQuery

import org.apache.cassandra.db.ReadCommand; //导入依赖的package包/类
private ColumnFamily remoteStorageQuery(String target, String dataTag){
	try {
		List<ReadCommand> command = new ArrayList<ReadCommand>();
		command.add(new SliceFromReadCommand(
				Metadata.MetaData_KS,
				ByteBufferUtil.bytes(target), 
				new QueryPath(Metadata.MetadataRegistry_CF),
				Column.decomposeName(dataTag, "admin_tag"),
				Column.decomposeName(dataTag, "admin_tag"),
				false,
				Integer.MAX_VALUE));

		List<Row> rows = StorageProxy.read(command, ConsistencyLevel.ANY);
		return rows.get(0).cf;
		 
	} catch (Exception e) {
		return null;
	}
}
 
开发者ID:dprguiuc,项目名称:Cassandra-Wasef,代码行数:20,代码来源:MetadataRegistry.java

示例14: runMayThrow

import org.apache.cassandra.db.ReadCommand; //导入依赖的package包/类
protected void runMayThrow() throws IOException
{
    try
    {
        resolver.resolve();
    }
    catch (DigestMismatchException e)
    {
        if (logger.isDebugEnabled())
            logger.debug("Digest mismatch:", e);

        ReadCommand readCommand = (ReadCommand) command;
        final RowRepairResolver repairResolver = new RowRepairResolver(readCommand.table, readCommand.key);
        IAsyncCallback repairHandler = new AsyncRepairCallback(repairResolver, endpoints.size());

        for (InetAddress endpoint : endpoints)
            MessagingService.instance().sendRR(readCommand, endpoint, repairHandler);
    }
}
 
开发者ID:devdattakulkarni,项目名称:Cassandra-KVPM,代码行数:20,代码来源:ReadCallback.java

示例15: searcherFor

import org.apache.cassandra.db.ReadCommand; //导入依赖的package包/类
/**
 * This method is invoked when a CQL query is executed.
 */
public Searcher searcherFor(ReadCommand command) {
	logger.trace("Getting searcher for {}", command);
	try {
		return service.searcher(command);
	} catch (Exception e) {
		logger.error("Error while searching", e);
		throw new InvalidRequestException(e.getMessage());
	}
}
 
开发者ID:jmiddleton,项目名称:cassandra-fhir-index,代码行数:13,代码来源:FhirIndex.java


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