-
Notifications
You must be signed in to change notification settings - Fork 199
/
Copy pathbatch_read_policy.go
70 lines (61 loc) · 2.65 KB
/
batch_read_policy.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
// Copyright 2014-2022 Aerospike, Inc.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package aerospike
// BatchReadPolicy attributes used in batch read commands.
type BatchReadPolicy struct {
// FilterExpression is the optional expression filter. If FilterExpression exists and evaluates to false, the specific batch key
// request is not performed and BatchRecord.ResultCode is set to types.FILTERED_OUT.
//
// Default: nil
FilterExpression *Expression
// ReadModeAP indicates read policy for AP (availability) namespaces.
ReadModeAP ReadModeAP //= ONE
// ReadModeSC indicates read policy for SC (strong consistency) namespaces.
ReadModeSC ReadModeSC //= SESSION;
// ReadTouchTTLPercent determines how record TTL (time to live) is affected on reads. When enabled, the server can
// efficiently operate as a read-based LRU cache where the least recently used records are expired.
// The value is expressed as a percentage of the TTL sent on the most recent write such that a read
// within this interval of the record’s end of life will generate a touch.
//
// For example, if the most recent write had a TTL of 10 hours and read_touch_ttl_percent is set to
// 80, the next read within 8 hours of the record's end of life (equivalent to 2 hours after the most
// recent write) will result in a touch, resetting the TTL to another 10 hours.
//
// Values:
//
// 0 : Use server config default-read-touch-ttl-pct for the record's namespace/set.
// -1 : Do not reset record TTL on reads.
// 1 - 100 : Reset record TTL on reads when within this percentage of the most recent write TTL.
// Default: 0
ReadTouchTTLPercent int32
}
// NewBatchReadPolicy returns a policy instance for BatchRead commands.
func NewBatchReadPolicy() *BatchReadPolicy {
return &BatchReadPolicy{
ReadModeAP: ReadModeAPOne,
ReadModeSC: ReadModeSCSession,
}
}
func (brp *BatchReadPolicy) toWritePolicy(bp *BatchPolicy) *WritePolicy {
wp := bp.toWritePolicy()
if brp != nil {
if brp.FilterExpression != nil {
wp.FilterExpression = brp.FilterExpression
}
wp.ReadModeAP = brp.ReadModeAP
wp.ReadModeSC = brp.ReadModeSC
wp.ReadTouchTTLPercent = brp.ReadTouchTTLPercent
}
return wp
}