-
Notifications
You must be signed in to change notification settings - Fork 455
/
types.go
135 lines (102 loc) · 3.96 KB
/
types.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
135
// Copyright (c) 2016 Uber Technologies, Inc.
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
// THE SOFTWARE.
package shard
import (
"math"
"github.com/m3db/m3/src/cluster/generated/proto/placementpb"
)
const (
// UnInitializedValue is the unintialized value used in proto.
UnInitializedValue int64 = 0
// DefaultShardCutoverNanos is the default shard-level cutover nanos
// if the value is not set in the proto message.
DefaultShardCutoverNanos int64 = 0
// DefaultShardCutoffNanos is the default shard-level cutoff nanos
// if the value is not set in the proto message.
DefaultShardCutoffNanos int64 = math.MaxInt64
)
// State represents the state of a shard.
type State int
const (
// Unknown represents a shard in unknown state.
Unknown State = iota
// Initializing represents a shard newly assigned to an instance.
Initializing
// Available represents a shard bootstraped and ready to serve.
Available
// Leaving represents a shard that is intending to be removed.
Leaving
)
// A Shard represents a piece of data owned by the service.
type Shard interface {
// ID returns the ID of the shard.
ID() uint32
// CutoverNanos returns when shard traffic is cut over.
CutoverNanos() int64
// SetCutoverNanos sets when shard traffic is cut over.
SetCutoverNanos(value int64) Shard
// CutoffNanos returns when shard traffic is cut off.
CutoffNanos() int64
// SetCutoffNanos sets when shard traffic is cut off.
SetCutoffNanos(value int64) Shard
// State returns the state of the shard.
State() State
// SetState sets the state of the shard.
SetState(s State) Shard
// Source returns the source of the shard.
SourceID() string
// SetSource sets the source of the shard.
SetSourceID(sourceID string) Shard
// Equals returns whether the shard equals to another shard.
Equals(s Shard) bool
// Proto returns the proto representation for the shard.
Proto() (*placementpb.Shard, error)
// Clone returns a clone of the Shard.
Clone() Shard
}
// Shards is a collection of shards owned by one ServiceInstance.
type Shards interface {
// All returns the shards sorted ascending.
All() []Shard
// AllIDs returns the shard IDs sorted ascending.
AllIDs() []uint32
// NumShards returns the number of the shards.
NumShards() int
// ShardsForState returns the shards in a certain state.
ShardsForState(state State) []Shard
// NumShardsForState returns the number of shards in a certain state.
NumShardsForState(state State) int
// Add adds a shard.
Add(shard Shard)
// Remove removes a shard.
Remove(shard uint32)
// Contains checks if a shard exists.
Contains(shard uint32) bool
// Shard returns the shard for the id.
Shard(id uint32) (Shard, bool)
// Equals returns whether the shards equals to another shards.
Equals(s Shards) bool
// String returns the string representation of the shards.
String() string
// Proto returns the proto representation for the shards.
Proto() ([]*placementpb.Shard, error)
// Clone returns a clone of the Shards.
Clone() Shards
}