-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathconfig_restore.go
134 lines (118 loc) · 4.48 KB
/
config_restore.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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
// Copyright 2024 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 backup
import (
"fmt"
a "github.com/aerospike/aerospike-client-go/v7"
"github.com/aerospike/backup-go/models"
)
// RestoreConfig contains configuration for the restore operation.
type RestoreConfig struct {
// InfoPolicy applies to Aerospike Info requests made during backup and restore
// If nil, the Aerospike client's default policy will be used.
InfoPolicy *a.InfoPolicy
// WritePolicy applies to Aerospike write operations made during backup and restore
// If nil, the Aerospike client's default policy will be used.
WritePolicy *a.WritePolicy
// Namespace details for the restore operation.
// By default, the data is restored to the namespace from which it was taken.
Namespace *RestoreNamespaceConfig `json:"namespace,omitempty"`
// Encryption details.
EncryptionPolicy *EncryptionPolicy
// Compression details.
CompressionPolicy *CompressionPolicy
// Configuration of retries for each restore write operation.
// If nil, no retries will be performed.
RetryPolicy *models.RetryPolicy
// Secret agent config.
SecretAgentConfig *SecretAgentConfig
// The sets to restore (optional, given an empty list, all sets will be restored).
SetList []string
// The bins to restore (optional, given an empty list, all bins will be restored).
BinList []string
// EncoderType describes an Encoder type that will be used on restoring.
// Default `EncoderTypeASB` = 0.
EncoderType EncoderType
// Parallel is the number of concurrent record readers from backup files.
Parallel int
// RecordsPerSecond limits restore records per second (rps) rate.
// Will not apply rps limit if RecordsPerSecond is zero (default).
RecordsPerSecond int
// Limits restore bandwidth (bytes per second).
// Will not apply rps limit if Bandwidth is zero (default).
Bandwidth int
// Don't restore any records.
NoRecords bool
// Don't restore any secondary indexes.
NoIndexes bool
// Don't restore any UDFs.
NoUDFs bool
// Disables the use of batch writes when restoring records to the Aerospike cluster.
DisableBatchWrites bool
// The max allowed number of records per batch write call.
BatchSize int
// Max number of parallel writers to target AS cluster.
MaxAsyncBatches int
// Amount of extra time-to-live to add to records that have expirable void-times.
// Must be set in seconds.
ExtraTTL int64
// Ignore permanent record-specific error.
// E.g.: AEROSPIKE_RECORD_TOO_BIG.
// By default, such errors are not ignored and restore terminates.
IgnoreRecordError bool
}
// NewDefaultRestoreConfig returns a new RestoreConfig with default values.
func NewDefaultRestoreConfig() *RestoreConfig {
return &RestoreConfig{
Parallel: 4,
BatchSize: 128,
MaxAsyncBatches: 16,
EncoderType: EncoderTypeASB,
}
}
func (c *RestoreConfig) validate() error {
if c.Parallel < MinParallel || c.Parallel > MaxParallel {
return fmt.Errorf("parallel must be between 1 and 1024, got %d", c.Parallel)
}
if c.Namespace != nil {
if err := c.Namespace.validate(); err != nil {
return fmt.Errorf("invalid restore namespace: %w", err)
}
}
if c.Bandwidth < 0 {
return fmt.Errorf("bandwidth value must not be negative, got %d", c.Bandwidth)
}
if c.RecordsPerSecond < 0 {
return fmt.Errorf("rps value must not be negative, got %d", c.RecordsPerSecond)
}
if c.BatchSize <= 0 {
return fmt.Errorf("batch size must be positive, got %d", c.BatchSize)
}
if c.MaxAsyncBatches <= 0 {
return fmt.Errorf("max async batches must be positive, got %d", c.MaxAsyncBatches)
}
if c.ExtraTTL < 0 {
return fmt.Errorf("extra ttl value must not be negative, got %d", c.ExtraTTL)
}
if err := c.CompressionPolicy.validate(); err != nil {
return fmt.Errorf("compression policy invalid: %w", err)
}
if err := c.EncryptionPolicy.validate(); err != nil {
return fmt.Errorf("encryption policy invalid: %w", err)
}
if err := c.SecretAgentConfig.validate(); err != nil {
return fmt.Errorf("secret agent invalid: %w", err)
}
return nil
}