2020-09-10 19:55:03 +08:00
|
|
|
syntax = "proto3";
|
2021-06-22 16:14:09 +08:00
|
|
|
package milvus.proto.rootcoord;
|
2020-09-10 19:55:03 +08:00
|
|
|
|
2021-06-22 16:14:09 +08:00
|
|
|
option go_package="github.com/milvus-io/milvus/internal/proto/rootcoordpb";
|
2020-10-24 18:04:57 +08:00
|
|
|
|
|
|
|
import "common.proto";
|
2021-01-18 19:32:08 +08:00
|
|
|
import "milvus.proto";
|
2021-01-18 21:39:56 +08:00
|
|
|
import "internal.proto";
|
2021-06-22 16:14:09 +08:00
|
|
|
import "proxy.proto";
|
2021-07-01 14:58:17 +08:00
|
|
|
import "data_coord.proto";
|
2022-03-30 21:11:28 +08:00
|
|
|
import "etcd_meta.proto";
|
2022-06-16 20:12:11 +08:00
|
|
|
import "index_coord.proto";
|
2020-09-10 19:55:03 +08:00
|
|
|
|
2021-06-22 16:14:09 +08:00
|
|
|
service RootCoord {
|
2021-03-12 14:22:09 +08:00
|
|
|
rpc GetComponentStates(internal.GetComponentStatesRequest) returns (internal.ComponentStates) {}
|
|
|
|
rpc GetTimeTickChannel(internal.GetTimeTickChannelRequest) returns(milvus.StringResponse) {}
|
|
|
|
rpc GetStatisticsChannel(internal.GetStatisticsChannelRequest) returns(milvus.StringResponse){}
|
2020-10-24 18:04:57 +08:00
|
|
|
/**
|
|
|
|
* @brief This method is used to create collection
|
|
|
|
*
|
|
|
|
* @param CreateCollectionRequest, use to provide collection information to be created.
|
|
|
|
*
|
|
|
|
* @return Status
|
|
|
|
*/
|
2021-01-18 19:32:08 +08:00
|
|
|
rpc CreateCollection(milvus.CreateCollectionRequest) returns (common.Status){}
|
2021-03-12 14:22:09 +08:00
|
|
|
|
2020-10-24 18:04:57 +08:00
|
|
|
/**
|
|
|
|
* @brief This method is used to delete collection.
|
|
|
|
*
|
|
|
|
* @param DropCollectionRequest, collection name is going to be deleted.
|
|
|
|
*
|
|
|
|
* @return Status
|
|
|
|
*/
|
2021-01-18 19:32:08 +08:00
|
|
|
rpc DropCollection(milvus.DropCollectionRequest) returns (common.Status) {}
|
2020-10-24 18:04:57 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief This method is used to test collection existence.
|
|
|
|
*
|
|
|
|
* @param HasCollectionRequest, collection name is going to be tested.
|
|
|
|
*
|
|
|
|
* @return BoolResponse
|
|
|
|
*/
|
2021-01-18 19:32:08 +08:00
|
|
|
rpc HasCollection(milvus.HasCollectionRequest) returns (milvus.BoolResponse) {}
|
2020-10-24 18:04:57 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief This method is used to get collection schema.
|
|
|
|
*
|
|
|
|
* @param DescribeCollectionRequest, target collection name.
|
|
|
|
*
|
|
|
|
* @return CollectionSchema
|
|
|
|
*/
|
2021-01-18 19:32:08 +08:00
|
|
|
rpc DescribeCollection(milvus.DescribeCollectionRequest) returns (milvus.DescribeCollectionResponse) {}
|
|
|
|
|
2021-09-18 11:13:51 +08:00
|
|
|
rpc CreateAlias(milvus.CreateAliasRequest) returns (common.Status) {}
|
|
|
|
rpc DropAlias(milvus.DropAliasRequest) returns (common.Status) {}
|
|
|
|
rpc AlterAlias(milvus.AlterAliasRequest) returns (common.Status) {}
|
|
|
|
|
2020-10-24 18:04:57 +08:00
|
|
|
/**
|
|
|
|
* @brief This method is used to list all collections.
|
|
|
|
*
|
|
|
|
* @return StringListResponse, collection name list
|
|
|
|
*/
|
2021-03-12 14:22:09 +08:00
|
|
|
rpc ShowCollections(milvus.ShowCollectionsRequest) returns (milvus.ShowCollectionsResponse) {}
|
2020-10-24 18:04:57 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief This method is used to create partition
|
|
|
|
*
|
|
|
|
* @return Status
|
|
|
|
*/
|
2021-01-18 19:32:08 +08:00
|
|
|
rpc CreatePartition(milvus.CreatePartitionRequest) returns (common.Status) {}
|
2020-10-24 18:04:57 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief This method is used to drop partition
|
|
|
|
*
|
|
|
|
* @return Status
|
|
|
|
*/
|
2021-01-18 19:32:08 +08:00
|
|
|
rpc DropPartition(milvus.DropPartitionRequest) returns (common.Status) {}
|
2020-10-24 18:04:57 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief This method is used to test partition existence.
|
|
|
|
*
|
|
|
|
* @return BoolResponse
|
|
|
|
*/
|
2021-01-18 19:32:08 +08:00
|
|
|
rpc HasPartition(milvus.HasPartitionRequest) returns (milvus.BoolResponse) {}
|
2020-10-24 18:04:57 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief This method is used to show partition information
|
|
|
|
*
|
|
|
|
* @param ShowPartitionRequest, target collection name.
|
|
|
|
*
|
|
|
|
* @return StringListResponse
|
|
|
|
*/
|
2021-03-12 14:22:09 +08:00
|
|
|
rpc ShowPartitions(milvus.ShowPartitionsRequest) returns (milvus.ShowPartitionsResponse) {}
|
2020-10-29 09:31:08 +08:00
|
|
|
|
2021-01-18 19:32:08 +08:00
|
|
|
rpc DescribeSegment(milvus.DescribeSegmentRequest) returns (milvus.DescribeSegmentResponse) {}
|
2021-03-12 14:22:09 +08:00
|
|
|
rpc ShowSegments(milvus.ShowSegmentsRequest) returns (milvus.ShowSegmentsResponse) {}
|
2022-03-30 21:11:28 +08:00
|
|
|
rpc DescribeSegments(DescribeSegmentsRequest) returns (DescribeSegmentsResponse) {}
|
2020-10-29 09:31:08 +08:00
|
|
|
|
2021-01-18 19:32:08 +08:00
|
|
|
rpc CreateIndex(milvus.CreateIndexRequest) returns (common.Status) {}
|
|
|
|
rpc DescribeIndex(milvus.DescribeIndexRequest) returns (milvus.DescribeIndexResponse) {}
|
2021-02-20 10:14:03 +08:00
|
|
|
rpc DropIndex(milvus.DropIndexRequest) returns (common.Status) {}
|
2022-06-16 20:12:11 +08:00
|
|
|
rpc GetIndexState(milvus.GetIndexStateRequest) returns (index.GetIndexStatesResponse) {}
|
2020-12-07 15:22:20 +08:00
|
|
|
|
2021-03-12 14:22:09 +08:00
|
|
|
rpc AllocTimestamp(AllocTimestampRequest) returns (AllocTimestampResponse) {}
|
|
|
|
rpc AllocID(AllocIDRequest) returns (AllocIDResponse) {}
|
2021-05-21 16:08:12 +08:00
|
|
|
rpc UpdateChannelTimeTick(internal.ChannelTimeTickMsg) returns (common.Status) {}
|
2021-06-17 17:45:56 +08:00
|
|
|
rpc ReleaseDQLMessageStream(proxy.ReleaseDQLMessageStreamRequest) returns (common.Status) {}
|
2022-05-19 10:13:56 +08:00
|
|
|
rpc InvalidateCollectionMetaCache(proxy.InvalidateCollMetaCacheRequest) returns (common.Status) {}
|
2021-07-02 11:16:20 +08:00
|
|
|
rpc SegmentFlushCompleted(data.SegmentFlushCompletedMsg) returns (common.Status) {}
|
2021-08-31 11:45:59 +08:00
|
|
|
|
2022-08-12 13:20:39 +08:00
|
|
|
rpc ShowConfigurations(internal.ShowConfigurationsRequest) returns (internal.ShowConfigurationsResponse){}
|
2021-08-31 11:45:59 +08:00
|
|
|
// https://wiki.lfaidata.foundation/display/MIL/MEP+8+--+Add+metrics+for+proxy
|
|
|
|
rpc GetMetrics(milvus.GetMetricsRequest) returns (milvus.GetMetricsResponse) {}
|
2022-03-11 17:13:59 +08:00
|
|
|
|
|
|
|
// https://wiki.lfaidata.foundation/display/MIL/MEP+24+--+Support+bulk+load
|
|
|
|
rpc Import(milvus.ImportRequest) returns (milvus.ImportResponse) {}
|
|
|
|
rpc GetImportState(milvus.GetImportStateRequest) returns (milvus.GetImportStateResponse) {}
|
2022-04-25 17:37:46 +08:00
|
|
|
rpc ListImportTasks(milvus.ListImportTasksRequest) returns (milvus.ListImportTasksResponse) {}
|
2022-03-11 17:13:59 +08:00
|
|
|
rpc ReportImport(ImportResult) returns (common.Status) {}
|
2022-04-11 19:49:34 +08:00
|
|
|
|
|
|
|
// https://wiki.lfaidata.foundation/display/MIL/MEP+27+--+Support+Basic+Authentication
|
|
|
|
rpc CreateCredential(internal.CredentialInfo) returns (common.Status) {}
|
|
|
|
rpc UpdateCredential(internal.CredentialInfo) returns (common.Status) {}
|
|
|
|
rpc DeleteCredential(milvus.DeleteCredentialRequest) returns (common.Status) {}
|
|
|
|
rpc ListCredUsers(milvus.ListCredUsersRequest) returns (milvus.ListCredUsersResponse) {}
|
|
|
|
// userd by proxy, not exposed to sdk
|
|
|
|
rpc GetCredential(GetCredentialRequest) returns (GetCredentialResponse) {}
|
2022-05-28 00:04:01 +08:00
|
|
|
|
|
|
|
// https://wiki.lfaidata.foundation/display/MIL/MEP+29+--+Support+Role-Based+Access+Control
|
|
|
|
rpc CreateRole(milvus.CreateRoleRequest) returns (common.Status) {}
|
|
|
|
rpc DropRole(milvus.DropRoleRequest) returns (common.Status) {}
|
|
|
|
rpc OperateUserRole(milvus.OperateUserRoleRequest) returns (common.Status) {}
|
|
|
|
rpc SelectRole(milvus.SelectRoleRequest) returns (milvus.SelectRoleResponse) {}
|
|
|
|
rpc SelectUser(milvus.SelectUserRequest) returns (milvus.SelectUserResponse) {}
|
|
|
|
rpc OperatePrivilege(milvus.OperatePrivilegeRequest) returns (common.Status) {}
|
|
|
|
rpc SelectGrant(milvus.SelectGrantRequest) returns (milvus.SelectGrantResponse) {}
|
|
|
|
rpc ListPolicy(internal.ListPolicyRequest) returns (internal.ListPolicyResponse) {}
|
2021-03-12 14:22:09 +08:00
|
|
|
}
|
2021-01-18 21:39:56 +08:00
|
|
|
|
2021-03-12 14:22:09 +08:00
|
|
|
message AllocTimestampRequest {
|
|
|
|
common.MsgBase base = 1;
|
|
|
|
uint32 count = 3;
|
|
|
|
}
|
2021-01-18 21:39:56 +08:00
|
|
|
|
2021-03-12 14:22:09 +08:00
|
|
|
message AllocTimestampResponse {
|
|
|
|
common.Status status = 1;
|
|
|
|
uint64 timestamp = 2;
|
|
|
|
uint32 count = 3;
|
|
|
|
}
|
2021-01-19 14:44:03 +08:00
|
|
|
|
2021-03-12 14:22:09 +08:00
|
|
|
message AllocIDRequest {
|
|
|
|
common.MsgBase base = 1;
|
|
|
|
uint32 count = 2;
|
|
|
|
}
|
2021-01-18 21:39:56 +08:00
|
|
|
|
2021-03-12 14:22:09 +08:00
|
|
|
message AllocIDResponse {
|
|
|
|
common.Status status = 1;
|
|
|
|
int64 ID = 2;
|
|
|
|
uint32 count = 3;
|
|
|
|
}
|
2022-03-11 17:13:59 +08:00
|
|
|
|
|
|
|
message ImportResult {
|
|
|
|
common.Status status = 1;
|
2022-03-21 15:47:23 +08:00
|
|
|
int64 task_id = 2; // id of the task
|
2022-03-23 19:29:25 +08:00
|
|
|
int64 datanode_id = 3; // id of the datanode which takes this task
|
|
|
|
common.ImportState state = 4; // state of the task
|
|
|
|
repeated int64 segments = 5; // id array of new sealed segments
|
|
|
|
repeated int64 auto_ids = 6; // auto-generated ids for auto-id primary key
|
|
|
|
int64 row_count = 7; // how many rows are imported by this task
|
|
|
|
repeated common.KeyValuePair infos = 8; // more informations about the task, file path, failed reason, etc.
|
2022-03-30 21:11:28 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// TODO: find a proper place for these segment-related messages.
|
|
|
|
|
|
|
|
message DescribeSegmentsRequest {
|
|
|
|
common.MsgBase base = 1;
|
|
|
|
int64 collectionID = 2;
|
|
|
|
repeated int64 segmentIDs = 3;
|
|
|
|
}
|
|
|
|
|
|
|
|
message SegmentBaseInfo {
|
|
|
|
int64 collectionID = 1; // in which collection.
|
|
|
|
int64 partitionID = 2; // in which partition.
|
|
|
|
int64 segmentID = 3;
|
|
|
|
}
|
|
|
|
|
|
|
|
message SegmentInfos {
|
|
|
|
SegmentBaseInfo base_info = 1; // base information.
|
|
|
|
repeated etcd.SegmentIndexInfo index_infos = 2; // multiple index infos.
|
|
|
|
map<int64, etcd.IndexInfo> extra_index_infos = 3; // index_id -> IndexInfo{index_name, index_id, index_params}
|
|
|
|
}
|
|
|
|
|
|
|
|
message DescribeSegmentsResponse {
|
|
|
|
common.Status status = 1;
|
|
|
|
int64 collectionID = 2;
|
|
|
|
map<int64, SegmentInfos> segment_infos = 3; // segment_id -> segment infos
|
|
|
|
}
|
2022-04-11 19:49:34 +08:00
|
|
|
|
|
|
|
message GetCredentialRequest {
|
|
|
|
// Not useful for now
|
|
|
|
common.MsgBase base = 1;
|
|
|
|
// username
|
|
|
|
string username = 2;
|
|
|
|
}
|
|
|
|
|
|
|
|
message GetCredentialResponse {
|
|
|
|
// Contain error_code and reason
|
|
|
|
common.Status status = 1;
|
|
|
|
// username
|
|
|
|
string username = 2;
|
2022-06-29 20:02:18 +08:00
|
|
|
// password stored in etcd/mysql
|
2022-04-11 19:49:34 +08:00
|
|
|
string password = 3;
|
2022-05-28 00:04:01 +08:00
|
|
|
}
|