/
collection.go
52 lines (45 loc) · 1.75 KB
/
collection.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
// Copyright (C) 2019-2021 Zilliz. All rights reserved.
//
// 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 entity defines entities used in sdk
package entity
// DefaultShardNumber const value for using Milvus default shard number.
const DefaultShardNumber int32 = 0
// DefaultConsistencyLevel const value for using Milvus default consistency level setting.
const DefaultConsistencyLevel ConsistencyLevel = ClBounded
// Collection represent collection meta in Milvus
type Collection struct {
ID int64 // collection id
Name string // collection name
Schema *Schema // collection schema, with fields schema and primary key definition
PhysicalChannels []string
VirtualChannels []string
Loaded bool
ConsistencyLevel ConsistencyLevel
ShardNum int32
}
// Partition represent partition meta in Milvus
type Partition struct {
ID int64 // partition id
Name string // partition name
Loaded bool // partition loaded
}
// ReplicaGroup represents a replica group
type ReplicaGroup struct {
ReplicaID int64
NodeIDs []int64
ShardReplicas []*ShardReplica
}
// ShardReplica represents a shard in the ReplicaGroup
type ShardReplica struct {
LeaderID int64
NodesIDs []int64
DmChannelName string
}