public interface RetryPolicy
| Modifier and Type | Interface and Description | 
|---|---|
| static class  | RetryPolicy.RetryDecisionA retry decision to adopt on a Cassandra exception (read/write timeout
 or unavailable exception). | 
| Modifier and Type | Method and Description | 
|---|---|
| void | close()Gets invoked at cluster shutdown. | 
| void | init(Cluster cluster)Gets invoked at cluster startup. | 
| RetryPolicy.RetryDecision | onReadTimeout(Statement statement,
             ConsistencyLevel cl,
             int requiredResponses,
             int receivedResponses,
             boolean dataRetrieved,
             int nbRetry)Defines whether to retry and at which consistency level on a read timeout. | 
| RetryPolicy.RetryDecision | onRequestError(Statement statement,
              ConsistencyLevel cl,
              DriverException e,
              int nbRetry)Defines whether to retry and at which consistency level on an
 unexpected error. | 
| RetryPolicy.RetryDecision | onUnavailable(Statement statement,
             ConsistencyLevel cl,
             int requiredReplica,
             int aliveReplica,
             int nbRetry)Defines whether to retry and at which consistency level on an
 unavailable exception. | 
| RetryPolicy.RetryDecision | onWriteTimeout(Statement statement,
              ConsistencyLevel cl,
              WriteType writeType,
              int requiredAcks,
              int receivedAcks,
              int nbRetry)Defines whether to retry and at which consistency level on a write timeout. | 
RetryPolicy.RetryDecision onReadTimeout(Statement statement, ConsistencyLevel cl, int requiredResponses, int receivedResponses, boolean dataRetrieved, int nbRetry)
requiredResponses >= receivedResponses if dataPresent is
 false (see
 ReadTimeoutException.wasDataRetrieved()).statement - the original query that timed out.cl - the requested consistency level of the read that timed out.
                          Note that this can never be a serial
                          consistency level.requiredResponses - the number of responses that were required to
                          achieve the requested consistency level.receivedResponses - the number of responses that had been received
                          by the time the timeout exception was raised.dataRetrieved - whether actual data (by opposition to data checksum)
                          was present in the received responses.nbRetry - the number of retry already performed for this operation.RetryDecision.RETHROW is returned,
 a ReadTimeoutException will
 be thrown for the operation.RetryPolicy.RetryDecision onWriteTimeout(Statement statement, ConsistencyLevel cl, WriteType writeType, int requiredAcks, int receivedAcks, int nbRetry)
not idempotent, the driver will never retry it on a
 write timeout (this method won't even be called).statement - the original query that timed out.cl - the requested consistency level of the write that timed out.
                     If the timeout occurred at the "paxos" phase of a
                     Lightweight transaction,
                     then cl will actually be the requested serial consistency level.
                     Beware that serial consistency levels should never be passed to a RetryDecision as this would
                     invariably trigger an InvalidQueryException.
                     Also, when cl is serial, then writeType is always CAS.writeType - the type of the write that timed out.requiredAcks - the number of acknowledgments that were required to
                     achieve the requested consistency level.receivedAcks - the number of acknowledgments that had been received
                     by the time the timeout exception was raised.nbRetry - the number of retry already performed for this operation.RetryDecision.RETHROW is returned,
 a WriteTimeoutException will
 be thrown for the operation.RetryPolicy.RetryDecision onUnavailable(Statement statement, ConsistencyLevel cl, int requiredReplica, int aliveReplica, int nbRetry)
statement - the original query for which the consistency level cannot
                        be achieved.cl - the requested consistency level for the operation.
                        If the operation failed at the "paxos" phase of a
                        Lightweight transaction,
                        then cl will actually be the requested serial consistency level.
                        Beware that serial consistency levels should never be passed to a RetryDecision as this would
                        invariably trigger an InvalidQueryException.requiredReplica - the number of replica that should have been
                        (known) alive for the operation to be attempted.aliveReplica - the number of replica that were know to be alive by
                        the coordinator of the operation.nbRetry - the number of retry already performed for this operation.RetryDecision.RETHROW is returned,
 an UnavailableException will
 be thrown for the operation.RetryPolicy.RetryDecision onRequestError(Statement statement, ConsistencyLevel cl, DriverException e, int nbRetry)
SocketOptions.getReadTimeoutMillis());OVERLOADED error or a SERVER_ERROR.not idempotent, the driver will never retry it
 (this method won't even be called).statement - the original query that failed.cl - the requested consistency level for the operation.
                  Note that this is not necessarily the achieved consistency level (if any),
                  and it is never a serial one.e - the exception that caused this request to fail.nbRetry - the number of retries already performed for this operation.RetryDecision.RETHROW is returned,
 the DriverException passed to this method will be thrown for the operation.void init(Cluster cluster)
cluster - the cluster that this policy is associated with.void close()
Copyright © 2012–2017. All rights reserved.