2021-01-14 06:24:14 +00:00
|
|
|
syntax = "proto3";
|
|
|
|
|
|
|
|
package milvus.proto.query;
|
|
|
|
|
2021-04-22 06:45:57 +00:00
|
|
|
option go_package = "github.com/milvus-io/milvus/internal/proto/querypb";
|
2021-01-14 06:24:14 +00:00
|
|
|
|
|
|
|
import "common.proto";
|
2021-01-22 06:28:06 +00:00
|
|
|
import "milvus.proto";
|
2021-01-14 06:24:14 +00:00
|
|
|
import "internal.proto";
|
2021-02-06 09:37:10 +00:00
|
|
|
import "schema.proto";
|
2021-06-22 02:42:07 +00:00
|
|
|
import "data_coord.proto";
|
2021-01-14 06:24:14 +00:00
|
|
|
|
2021-06-22 08:44:09 +00:00
|
|
|
service QueryCoord {
|
2021-03-12 06:22:09 +00:00
|
|
|
rpc GetComponentStates(internal.GetComponentStatesRequest) returns (internal.ComponentStates) {}
|
|
|
|
rpc GetTimeTickChannel(internal.GetTimeTickChannelRequest) returns(milvus.StringResponse) {}
|
|
|
|
rpc GetStatisticsChannel(internal.GetStatisticsChannelRequest) returns(milvus.StringResponse){}
|
|
|
|
|
|
|
|
rpc ShowCollections(ShowCollectionsRequest) returns (ShowCollectionsResponse) {}
|
|
|
|
rpc ShowPartitions(ShowPartitionsRequest) returns (ShowPartitionsResponse) {}
|
|
|
|
|
|
|
|
rpc LoadPartitions(LoadPartitionsRequest) returns (common.Status) {}
|
|
|
|
rpc ReleasePartitions(ReleasePartitionsRequest) returns (common.Status) {}
|
|
|
|
rpc LoadCollection(LoadCollectionRequest) returns (common.Status) {}
|
|
|
|
rpc ReleaseCollection(ReleaseCollectionRequest) returns (common.Status) {}
|
|
|
|
|
|
|
|
rpc CreateQueryChannel(CreateQueryChannelRequest) returns (CreateQueryChannelResponse) {}
|
|
|
|
rpc GetPartitionStates(GetPartitionStatesRequest) returns (GetPartitionStatesResponse) {}
|
|
|
|
rpc GetSegmentInfo(GetSegmentInfoRequest) returns (GetSegmentInfoResponse) {}
|
2021-08-17 02:06:11 +00:00
|
|
|
|
|
|
|
// https://wiki.lfaidata.foundation/display/MIL/MEP+8+--+Add+metrics+for+proxy
|
|
|
|
rpc GetMetrics(milvus.GetMetricsRequest) returns (milvus.GetMetricsResponse) {}
|
2021-03-12 06:22:09 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
service QueryNode {
|
|
|
|
rpc GetComponentStates(internal.GetComponentStatesRequest) returns (internal.ComponentStates) {}
|
|
|
|
rpc GetTimeTickChannel(internal.GetTimeTickChannelRequest) returns(milvus.StringResponse) {}
|
|
|
|
rpc GetStatisticsChannel(internal.GetStatisticsChannelRequest) returns(milvus.StringResponse){}
|
|
|
|
|
|
|
|
rpc AddQueryChannel(AddQueryChannelRequest) returns (common.Status) {}
|
|
|
|
rpc RemoveQueryChannel(RemoveQueryChannelRequest) returns (common.Status) {}
|
|
|
|
rpc WatchDmChannels(WatchDmChannelsRequest) returns (common.Status) {}
|
|
|
|
rpc LoadSegments(LoadSegmentsRequest) returns (common.Status) {}
|
|
|
|
rpc ReleaseCollection(ReleaseCollectionRequest) returns (common.Status) {}
|
|
|
|
rpc ReleasePartitions(ReleasePartitionsRequest) returns (common.Status) {}
|
|
|
|
rpc ReleaseSegments(ReleaseSegmentsRequest) returns (common.Status) {}
|
|
|
|
rpc GetSegmentInfo(GetSegmentInfoRequest) returns (GetSegmentInfoResponse) {}
|
2021-08-17 02:06:11 +00:00
|
|
|
|
|
|
|
// https://wiki.lfaidata.foundation/display/MIL/MEP+8+--+Add+metrics+for+proxy
|
|
|
|
rpc GetMetrics(milvus.GetMetricsRequest) returns (milvus.GetMetricsResponse) {}
|
2021-03-12 06:22:09 +00:00
|
|
|
}
|
|
|
|
|
2021-06-22 08:44:09 +00:00
|
|
|
//--------------------query coordinator proto------------------
|
2021-03-12 06:22:09 +00:00
|
|
|
message ShowCollectionsRequest {
|
2021-01-16 07:06:19 +00:00
|
|
|
common.MsgBase base = 1;
|
2021-09-22 12:04:13 +00:00
|
|
|
// Not useful for now
|
2021-01-16 07:31:10 +00:00
|
|
|
int64 dbID = 2;
|
2021-08-02 14:39:25 +00:00
|
|
|
repeated int64 collectionIDs = 3;
|
2021-01-14 06:24:14 +00:00
|
|
|
}
|
|
|
|
|
2021-03-12 06:22:09 +00:00
|
|
|
message ShowCollectionsResponse {
|
2021-01-16 07:31:10 +00:00
|
|
|
common.Status status = 1;
|
|
|
|
repeated int64 collectionIDs = 2;
|
2021-08-02 14:39:25 +00:00
|
|
|
repeated int64 inMemory_percentages = 3;
|
2021-01-14 06:24:14 +00:00
|
|
|
}
|
|
|
|
|
2021-06-15 04:41:40 +00:00
|
|
|
message ShowPartitionsRequest {
|
|
|
|
common.MsgBase base = 1;
|
|
|
|
int64 dbID = 2;
|
|
|
|
int64 collectionID = 3;
|
2021-08-02 14:39:25 +00:00
|
|
|
repeated int64 partitionIDs = 4;
|
2021-06-15 04:41:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
message ShowPartitionsResponse {
|
|
|
|
common.Status status = 1;
|
|
|
|
repeated int64 partitionIDs = 2;
|
2021-08-02 14:39:25 +00:00
|
|
|
repeated int64 inMemory_percentages = 3;
|
2021-06-15 04:41:40 +00:00
|
|
|
}
|
|
|
|
|
2021-01-14 06:24:14 +00:00
|
|
|
message LoadCollectionRequest {
|
2021-01-16 07:06:19 +00:00
|
|
|
common.MsgBase base = 1;
|
2021-01-16 07:31:10 +00:00
|
|
|
int64 dbID = 2;
|
2021-01-14 06:24:14 +00:00
|
|
|
int64 collectionID = 3;
|
2021-02-06 09:37:10 +00:00
|
|
|
schema.CollectionSchema schema = 4;
|
2021-01-14 06:24:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
message ReleaseCollectionRequest {
|
2021-01-16 07:06:19 +00:00
|
|
|
common.MsgBase base = 1;
|
2021-01-16 07:31:10 +00:00
|
|
|
int64 dbID = 2;
|
2021-01-14 06:24:14 +00:00
|
|
|
int64 collectionID = 3;
|
2021-06-19 03:45:09 +00:00
|
|
|
int64 nodeID = 4;
|
2021-01-14 06:24:14 +00:00
|
|
|
}
|
|
|
|
|
2021-06-15 04:41:40 +00:00
|
|
|
message LoadPartitionsRequest {
|
2021-01-16 07:06:19 +00:00
|
|
|
common.MsgBase base = 1;
|
2021-01-16 07:31:10 +00:00
|
|
|
int64 dbID = 2;
|
|
|
|
int64 collectionID = 3;
|
2021-06-15 04:41:40 +00:00
|
|
|
repeated int64 partitionIDs = 4;
|
|
|
|
schema.CollectionSchema schema = 5;
|
2021-01-14 06:24:14 +00:00
|
|
|
}
|
|
|
|
|
2021-06-15 04:41:40 +00:00
|
|
|
message ReleasePartitionsRequest {
|
|
|
|
common.MsgBase base = 1;
|
|
|
|
int64 dbID = 2;
|
|
|
|
int64 collectionID = 3;
|
|
|
|
repeated int64 partitionIDs = 4;
|
2021-06-19 03:45:09 +00:00
|
|
|
int64 nodeID = 5;
|
2021-06-15 04:41:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
message CreateQueryChannelRequest {
|
|
|
|
int64 collectionID = 1;
|
2021-06-18 02:33:58 +00:00
|
|
|
int64 proxyID = 2;
|
2021-06-15 04:41:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
message CreateQueryChannelResponse {
|
2021-01-16 07:31:10 +00:00
|
|
|
common.Status status = 1;
|
2021-06-15 04:41:40 +00:00
|
|
|
string request_channel = 2;
|
|
|
|
string result_channel = 3;
|
|
|
|
}
|
|
|
|
|
|
|
|
message GetPartitionStatesRequest {
|
|
|
|
common.MsgBase base = 1;
|
|
|
|
int64 dbID = 2;
|
|
|
|
int64 collectionID = 3;
|
|
|
|
repeated int64 partitionIDs = 4;
|
2021-01-14 06:24:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
enum PartitionState {
|
|
|
|
NotExist = 0;
|
|
|
|
NotPresent = 1;
|
2021-01-22 06:28:06 +00:00
|
|
|
OnDisk = 2;
|
2021-01-14 06:24:14 +00:00
|
|
|
PartialInMemory = 3;
|
|
|
|
InMemory = 4;
|
|
|
|
PartialInGPU = 5;
|
|
|
|
InGPU = 6;
|
|
|
|
}
|
|
|
|
|
|
|
|
message PartitionStates {
|
|
|
|
int64 partitionID = 1;
|
|
|
|
PartitionState state = 2;
|
2021-08-02 14:39:25 +00:00
|
|
|
int64 inMemory_percentage = 3;
|
2021-01-14 06:24:14 +00:00
|
|
|
}
|
|
|
|
|
2021-03-12 06:22:09 +00:00
|
|
|
message GetPartitionStatesResponse {
|
2021-01-16 07:31:10 +00:00
|
|
|
common.Status status = 1;
|
|
|
|
repeated PartitionStates partition_descriptions = 2;
|
2021-01-14 06:24:14 +00:00
|
|
|
}
|
|
|
|
|
2021-06-15 04:41:40 +00:00
|
|
|
message GetSegmentInfoRequest {
|
2021-01-16 07:06:19 +00:00
|
|
|
common.MsgBase base = 1;
|
2021-10-20 11:47:35 +00:00
|
|
|
repeated int64 segmentIDs = 2; // deprecated
|
|
|
|
int64 collectionID = 3;
|
2021-01-14 06:24:14 +00:00
|
|
|
}
|
|
|
|
|
2021-06-15 04:41:40 +00:00
|
|
|
message SegmentInfo {
|
|
|
|
int64 segmentID = 1;
|
|
|
|
int64 collectionID = 2;
|
|
|
|
int64 partitionID = 3;
|
|
|
|
int64 nodeID = 4;
|
|
|
|
int64 mem_size = 5;
|
|
|
|
int64 num_rows = 6;
|
|
|
|
string index_name = 7;
|
|
|
|
int64 indexID = 8;
|
|
|
|
string channelID = 9;
|
|
|
|
SegmentState segment_state = 10;
|
2021-01-14 06:24:14 +00:00
|
|
|
}
|
|
|
|
|
2021-06-15 04:41:40 +00:00
|
|
|
message GetSegmentInfoResponse {
|
2021-01-16 07:31:10 +00:00
|
|
|
common.Status status = 1;
|
2021-06-15 04:41:40 +00:00
|
|
|
repeated SegmentInfo infos = 2;
|
2021-01-14 06:24:14 +00:00
|
|
|
}
|
|
|
|
|
2021-06-15 04:41:40 +00:00
|
|
|
//-----------------query node proto----------------
|
2021-03-12 06:22:09 +00:00
|
|
|
message AddQueryChannelRequest {
|
2021-01-16 07:06:19 +00:00
|
|
|
common.MsgBase base = 1;
|
2021-06-15 04:41:40 +00:00
|
|
|
int64 nodeID = 2;
|
|
|
|
int64 collectionID = 3;
|
|
|
|
string request_channelID = 4;
|
|
|
|
string result_channelID = 5;
|
2021-10-11 10:48:29 +00:00
|
|
|
repeated int64 global_sealed_segmentID = 6;
|
|
|
|
internal.MsgPosition seek_position = 7;
|
2021-10-15 12:35:05 +00:00
|
|
|
repeated SegmentInfo global_sealed_segments = 8;
|
2021-01-14 06:24:14 +00:00
|
|
|
}
|
|
|
|
|
2021-03-12 06:22:09 +00:00
|
|
|
message RemoveQueryChannelRequest {
|
2021-06-15 04:41:40 +00:00
|
|
|
common.MsgBase base = 1;
|
|
|
|
int64 nodeID = 2;
|
|
|
|
int64 collectionID = 3;
|
|
|
|
string request_channelID = 4;
|
|
|
|
string result_channelID = 5;
|
2021-01-14 06:24:14 +00:00
|
|
|
}
|
|
|
|
|
2021-06-15 04:41:40 +00:00
|
|
|
//message excludedSegmentInfo {
|
|
|
|
// int64 segmentID = 1;
|
|
|
|
// internal.MsgPosition pos = 2;
|
|
|
|
//}
|
|
|
|
|
|
|
|
//message WatchDmChannelInfo {
|
|
|
|
// string channelID = 1;
|
|
|
|
// internal.MsgPosition pos = 2;
|
|
|
|
//}
|
2021-03-11 02:08:46 +00:00
|
|
|
|
2021-03-12 06:22:09 +00:00
|
|
|
message WatchDmChannelsRequest {
|
2021-01-16 07:06:19 +00:00
|
|
|
common.MsgBase base = 1;
|
2021-06-15 04:41:40 +00:00
|
|
|
int64 nodeID = 2;
|
|
|
|
int64 collectionID = 3;
|
|
|
|
int64 partitionID = 4;
|
2021-06-16 03:09:56 +00:00
|
|
|
repeated data.VchannelInfo infos = 5;
|
2021-06-15 04:41:40 +00:00
|
|
|
schema.CollectionSchema schema = 6;
|
2021-06-16 03:09:56 +00:00
|
|
|
repeated data.SegmentInfo exclude_infos = 7;
|
2021-06-15 04:41:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
enum TriggerCondition {
|
|
|
|
handoff = 0;
|
|
|
|
loadBalance = 1;
|
|
|
|
grpcRequest = 2;
|
|
|
|
nodeDown = 3;
|
|
|
|
}
|
|
|
|
|
|
|
|
//message FieldBinlogPath {
|
|
|
|
// int64 filedID = 1;
|
|
|
|
// repeated string binlog_path = 2;
|
|
|
|
//}
|
|
|
|
|
|
|
|
//used for handoff task
|
|
|
|
message SegmentLoadInfo {
|
|
|
|
int64 segmentID = 1;
|
|
|
|
int64 partitionID = 2;
|
|
|
|
int64 collectionID = 3;
|
|
|
|
int64 dbID = 4;
|
|
|
|
int64 flush_time = 5;
|
2021-06-16 03:09:56 +00:00
|
|
|
repeated data.FieldBinlog binlog_paths = 6;
|
2021-09-07 03:35:18 +00:00
|
|
|
int64 num_of_rows = 7;
|
2021-01-14 06:24:14 +00:00
|
|
|
}
|
|
|
|
|
2021-03-12 06:22:09 +00:00
|
|
|
message LoadSegmentsRequest {
|
2021-01-16 07:06:19 +00:00
|
|
|
common.MsgBase base = 1;
|
2021-06-15 04:41:40 +00:00
|
|
|
int64 nodeID = 2;
|
|
|
|
repeated SegmentLoadInfo infos = 3;
|
|
|
|
schema.CollectionSchema schema = 4;
|
|
|
|
TriggerCondition load_condition = 5;
|
2021-01-14 06:24:14 +00:00
|
|
|
}
|
|
|
|
|
2021-03-12 06:22:09 +00:00
|
|
|
message ReleaseSegmentsRequest {
|
2021-01-16 07:06:19 +00:00
|
|
|
common.MsgBase base = 1;
|
2021-06-15 04:41:40 +00:00
|
|
|
int64 nodeID = 2;
|
2021-09-22 12:06:09 +00:00
|
|
|
// Not useful for now
|
2021-06-15 04:41:40 +00:00
|
|
|
int64 dbID = 3;
|
|
|
|
int64 collectionID = 4;
|
|
|
|
repeated int64 partitionIDs = 5;
|
|
|
|
repeated int64 segmentIDs = 6;
|
2021-01-14 06:24:14 +00:00
|
|
|
}
|
|
|
|
|
2021-06-15 04:41:40 +00:00
|
|
|
//----------------etcd-----------------
|
|
|
|
enum SegmentState {
|
|
|
|
None = 0;
|
|
|
|
Growing = 1;
|
|
|
|
Frozen = 2;
|
|
|
|
sealing = 3;
|
|
|
|
sealed = 4;
|
|
|
|
}
|
|
|
|
|
2021-08-02 14:39:25 +00:00
|
|
|
enum LoadType {
|
|
|
|
LoadPartition = 0;
|
|
|
|
loadCollection = 1;
|
|
|
|
}
|
|
|
|
|
2021-06-15 04:41:40 +00:00
|
|
|
message DmChannelInfo {
|
|
|
|
int64 nodeID_loaded = 1;
|
|
|
|
repeated string channelIDs = 2;
|
|
|
|
}
|
|
|
|
|
|
|
|
message QueryChannelInfo {
|
|
|
|
int64 collectionID = 1;
|
|
|
|
string query_channelID = 2;
|
|
|
|
string query_result_channelID = 3;
|
|
|
|
}
|
|
|
|
|
|
|
|
message CollectionInfo {
|
|
|
|
int64 collectionID = 1;
|
|
|
|
repeated int64 partitionIDs = 2;
|
2021-08-02 14:39:25 +00:00
|
|
|
repeated PartitionStates partition_states = 3;
|
|
|
|
repeated DmChannelInfo channel_infos = 4;
|
|
|
|
LoadType load_type = 5;
|
|
|
|
schema.CollectionSchema schema = 6;
|
|
|
|
repeated int64 released_partitionIDs = 7;
|
|
|
|
int64 inMemory_percentage = 8;
|
2021-06-15 04:41:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
message HandoffSegments {
|
|
|
|
common.MsgBase base = 1;
|
|
|
|
repeated SegmentLoadInfo infos = 2;
|
|
|
|
}
|
|
|
|
|
|
|
|
message LoadBalanceSegmentInfo {
|
2021-02-04 03:40:14 +00:00
|
|
|
int64 segmentID = 1;
|
2021-06-15 04:41:40 +00:00
|
|
|
int64 partitionID = 2;
|
|
|
|
int64 collectionID = 3;
|
|
|
|
int64 source_nodeID = 4;
|
|
|
|
int64 dst_nodeID = 5;
|
|
|
|
bool source_done = 6;
|
|
|
|
bool dst_done = 7;
|
|
|
|
bool valid_info = 8;
|
2021-02-04 03:40:14 +00:00
|
|
|
}
|
|
|
|
|
2021-06-19 03:45:09 +00:00
|
|
|
message LoadBalanceRequest {
|
2021-02-04 03:40:14 +00:00
|
|
|
common.MsgBase base = 1;
|
2021-06-19 03:45:09 +00:00
|
|
|
repeated int64 source_nodeIDs = 2;
|
|
|
|
TriggerCondition balance_reason = 3;
|
2021-06-22 02:42:07 +00:00
|
|
|
}
|
2021-10-09 06:45:00 +00:00
|
|
|
|
|
|
|
//---------------- common query proto -----------------
|
|
|
|
message SealedSegmentsChangeInfo {
|
|
|
|
common.MsgBase base = 1;
|
|
|
|
int64 online_nodeID = 2;
|
2021-10-11 07:40:38 +00:00
|
|
|
repeated SegmentInfo online_segments = 3;
|
2021-10-09 06:45:00 +00:00
|
|
|
int64 offline_nodeID = 4;
|
2021-10-11 07:40:38 +00:00
|
|
|
repeated SegmentInfo offline_segments = 5;
|
2021-10-09 06:45:00 +00:00
|
|
|
}
|