Policies provide the ability to modify the behavior of operations.
This document provides information on the structure of policy objects for specific operations and the allowed values for some of the policies.
Policy objects are structs which define the behavior of associated operations.
When invoking an operation, you can choose:
- pass
nil
as policy. A relevant Policy with default values will be generated automatically. - Use a generator to make the policy; e.g.
NewWritePolicy(gen, ttl)
- Generate a policy object directly; e.g.
Policy{
Priority: Priority.DEFAULT,
Timeout: 0 * time.Millisecond, // no timeout
MaxRetries: 2,
SleepBetweenRetries: 500 * time.Millisecond,
SleepMultiplier: 1.5
}
Usage Example:
client.Get(nil, key);
client.Get(NewPolicy(), key);
A policy effecting the behaviour of read operations.
Attributes:
Priority
– Specifies the behavior for the key. For values, see Priority Values. * Default:Priority.DEFAULT
Timeout
– time.Duration datatype. Maximum time to wait for the operation to complete. If 0 (zero), then the value means there will be no timeout enforced. * Default:0 * time.Milliseconds
(no timeout)MaxRetries
– Number of times to try on connection errors. * Default:2
SleepBetweenRetries
– Duration of waiting between retries. * Default:500 * time.Milliseconds
SleepMultiplier
- The multiplying factor to be used for exponential backoff during retries. * Default:1.0
A policy effecting the behaviour of write operations.
Includes All Base Policy attributes, plus:
RecordExistsAction
– Qualify how to handle writes where the record already exists. For values, see RecordExistsAction Values. * Default:RecordExistsAction.UPDATE
GenerationPolicy
– Qualify how to handle record writes based on record generation. For values, see GenerationPolicy Values. * Default:GenerationPolicy.NONE
(generation is not used to restrict writes)Generation
– Expected generation. Generation is the number of times a record has been modified (including creation) on the server. If a write operation is creating a record, the expected generation would be 0 * Default:0
Expiration
– Record expiration. Also known as ttl (time to live). Seconds record will live before being removed by the server. Expiration values: * -1: Never expire for Aerospike 2 server versions >= 2.7.2 and Aerospike 3 server versions >= 3.1.4. Do not use -1 for older servers. * 0: Default to namespace configuration variable "default-ttl" on the server. * > 0: Actual expiration in seconds. * Default:0
A policy effecting the behaviour of query operations.
Includes All Base Policy attributes, plus:
MaxConcurrentNodes
– Maximum number of concurrent requests to server nodes at any point in time. If there are 16 nodes in the cluster and maxConcurrentNodes is 8, then queries will be made to 8 nodes in parallel. When a query completes, a new query will be issued until all 16 nodes have been queried. * Default:0
All nodes.RecordQueueSize
– Number of records to place in queue before blocking. Records received from multiple server nodes will be placed in a queue. A separate goroutine consumes these records in parallel. If the queue is full, the producer goroutines will block until records are consumed. * Default:50
A policy effecting the behaviour of scan operations.
Includes All Base Policy attributes, plus:
ScanPercent
– ScanPercent determines percent of data to scan. Valid integer range is 1 to 100. * Default:100
All records.MaxConcurrentNodes
– Maximum number of concurrent requests to server nodes at any point in time. If there are 16 nodes in the cluster and maxConcurrentNodes is 8, then scans will be made to 8 nodes in parallel. When a scan completes, a new scan will be issued until all 16 nodes have been queried. * Default:0
All nodes together.ConcurrentNodes
– Issue scan requests in parallel or serially. * Default:true
Concurrently.IncludeBinData
– Indicates if bin data is retrieved. If false, only record metadata are retrieved. * Default:true
FailOnClusterChange
– Terminate scan if cluster in fluctuating state. * Default:true
RecordQueueSize
– Number of records to place in queue before blocking. Records received from multiple server nodes will be placed in a queue. A separate goroutine consumes these records in parallel. If the queue is full, the producer goroutines will block until records are consumed. * Default:5000
The following are values allowed for various policies.
Writes a record, regardless of generation.
Writes a record, ONLY if generations are equal.
Writes a record, ONLY if local generation is greater-than remote generation.
Writes a record creating a duplicate, ONLY if the generation collides.
Create or update record.
Merge write command bins with existing bins.
Update record only. Fail if record does not exist.
Merge write command bins with existing bins.
Create or replace record.
Delete existing bins not referenced by write command bins.
Supported by Aerospike 2 server versions >= 2.7.5 and
Aerospike 3 server versions >= 3.1.6.
Replace record only. Fail if record does not exist.
Delete existing bins not referenced by write command bins.
Supported by Aerospike 2 server versions >= 2.7.5 and
Aerospike 3 server versions >= 3.1.6.
Create only. Fail if record exists.
The server defines the priority.
Run the database operation in a background thread.
Run the database operation at medium priority.
Run the database operation at the highest priority.