com.datastax.dse.driver.api.core.cql.continuous.ContinuousSession Maven / Gradle / Ivy
/*
* Copyright DataStax, Inc.
*
* This software can be used solely with DataStax Enterprise. Please consult the license at
* http://www.datastax.com/terms/datastax-dse-driver-license-terms
*/
package com.datastax.dse.driver.api.core.cql.continuous;
import com.datastax.dse.driver.internal.core.cql.continuous.ContinuousCqlRequestAsyncProcessor;
import com.datastax.dse.driver.internal.core.cql.continuous.ContinuousCqlRequestSyncProcessor;
import com.datastax.oss.driver.api.core.DefaultConsistencyLevel;
import com.datastax.oss.driver.api.core.cql.Statement;
import com.datastax.oss.driver.api.core.loadbalancing.LoadBalancingPolicy;
import com.datastax.oss.driver.api.core.metadata.token.Token;
import com.datastax.oss.driver.api.core.session.Session;
import edu.umd.cs.findbugs.annotations.NonNull;
import java.nio.ByteBuffer;
import java.util.Objects;
import java.util.concurrent.CompletionStage;
/**
* A session that has the ability to execute continuous paging queries.
*
* Continuous paging is a new method of streaming bulk amounts of records from Datastax
* Enterprise (DSE) to the Datastax Java Driver, available since DSE 5.1. It is mainly intended to
* be leveraged by DSE
* Analytics and Apache Spark™, or by any similar analytics tool that needs to read large
* portions of a table in one single operation, as quick and reliably as possible.
*
*
Continuous paging requires the following three conditions to be met on the client side:
*
*
* - The statement must target a single partition or a token range owned by one single replica;
* in practice, this means that the statement must have either a {@linkplain
* Statement#setRoutingKey(ByteBuffer) routing key} or a {@linkplain
* Statement#setRoutingToken(Token) routing token} set;
*
- The coordinator must be a replica; in practice, this is usually achieved by using
* token-aware routing (if you are using the driver's default {@link LoadBalancingPolicy},
* then this condition is met);
*
- The consistency level must be {@link DefaultConsistencyLevel#ONE ONE} (or {@link
* DefaultConsistencyLevel#LOCAL_ONE LOCAL_ONE}).
*
*
* It's the caller's responsibility to make sure that the above conditions are met. If this is
* not the case, continuous paging will silently degrade into a normal read operation, and the
* coordinator will retrieve pages one by one from replicas.
*
*
Note that when the continuous paging optimization kicks in (range read at {@code ONE}
* performed directly on a replica), the snitch is bypassed and the coordinator will always chose
* itself as a replica. Therefore, other functionality such as probabilistic read repair and
* speculative retry is also not available when contacting a replica at {@code ONE}.
*
*
Continuous paging is disabled by default and needs to be activated server-side. See Enabling
* continuous paging in the DSE docs to learn how to enable it.
*
* @see DSE
* Continuous Paging Tuning and Support Guide
*/
public interface ContinuousSession extends Session {
/**
* Executes the provided query with continuous paging synchronously.
*
*
This method takes care of chaining the successive results into a convenient iterable,
* provided that you always access the result from the same thread. For more flexibility, consider
* using the {@linkplain #executeContinuouslyAsync(Statement) asynchronous variant} of this method
* instead.
*
* @param statement the query to execute.
* @return a synchronous iterable on the results.
*/
@NonNull
default ContinuousResultSet executeContinuously(@NonNull Statement statement) {
return Objects.requireNonNull(
execute(statement, ContinuousCqlRequestSyncProcessor.CONTINUOUS_RESULT_SYNC));
}
/**
* Executes the provided query with continuous paging asynchronously.
*
*
The server will push all requested pages asynchronously, according to the options defined in
* the current execution profile. The client should consume all pages as quickly as possible, to
* avoid blocking the server for too long. The server will adjust the rate according to the client
* speed, but it will give up if the client does not consume any pages in a period of time equal
* to the read request timeout.
*
* @param statement the query to execute.
* @return a future to the first asynchronous result.
*/
@NonNull
default CompletionStage executeContinuouslyAsync(
@NonNull Statement statement) {
return Objects.requireNonNull(
execute(statement, ContinuousCqlRequestAsyncProcessor.CONTINUOUS_RESULT_ASYNC));
}
}