2021-04-19 07:15:33 +00:00
|
|
|
// Copyright (C) 2019-2020 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.
|
|
|
|
|
2021-03-05 07:21:33 +00:00
|
|
|
package types
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
|
2021-04-22 06:45:57 +00:00
|
|
|
"github.com/milvus-io/milvus/internal/proto/commonpb"
|
|
|
|
"github.com/milvus-io/milvus/internal/proto/datapb"
|
|
|
|
"github.com/milvus-io/milvus/internal/proto/indexpb"
|
|
|
|
"github.com/milvus-io/milvus/internal/proto/internalpb"
|
|
|
|
"github.com/milvus-io/milvus/internal/proto/milvuspb"
|
|
|
|
"github.com/milvus-io/milvus/internal/proto/proxypb"
|
|
|
|
"github.com/milvus-io/milvus/internal/proto/querypb"
|
2021-06-22 08:14:09 +00:00
|
|
|
"github.com/milvus-io/milvus/internal/proto/rootcoordpb"
|
2021-05-26 12:14:30 +00:00
|
|
|
"github.com/milvus-io/milvus/internal/util/sessionutil"
|
2021-10-09 02:10:59 +00:00
|
|
|
"github.com/milvus-io/milvus/internal/util/typeutil"
|
2021-03-05 07:21:33 +00:00
|
|
|
)
|
|
|
|
|
2021-09-28 14:06:06 +00:00
|
|
|
// TimeTickProvider is the interface all services implement
|
2021-03-05 07:21:33 +00:00
|
|
|
type TimeTickProvider interface {
|
|
|
|
GetTimeTickChannel(ctx context.Context) (*milvuspb.StringResponse, error)
|
|
|
|
}
|
|
|
|
|
2021-09-28 14:06:06 +00:00
|
|
|
// Component is the interface all services implement
|
2021-03-05 07:21:33 +00:00
|
|
|
type Component interface {
|
|
|
|
Init() error
|
|
|
|
Start() error
|
|
|
|
Stop() error
|
2021-03-12 06:22:09 +00:00
|
|
|
GetComponentStates(ctx context.Context) (*internalpb.ComponentStates, error)
|
2021-03-05 07:21:33 +00:00
|
|
|
GetStatisticsChannel(ctx context.Context) (*milvuspb.StringResponse, error)
|
2021-05-25 07:06:05 +00:00
|
|
|
Register() error
|
2021-03-05 07:21:33 +00:00
|
|
|
}
|
|
|
|
|
2021-09-28 14:06:06 +00:00
|
|
|
// DataNode is the interface `datanode` package implements
|
2021-03-05 10:14:59 +00:00
|
|
|
type DataNode interface {
|
2021-03-05 07:21:33 +00:00
|
|
|
Component
|
|
|
|
|
2021-03-12 06:22:09 +00:00
|
|
|
WatchDmChannels(ctx context.Context, req *datapb.WatchDmChannelsRequest) (*commonpb.Status, error)
|
2021-09-29 02:37:59 +00:00
|
|
|
|
|
|
|
// FlushSegments notifies DataNode to flush the segments req provids. The flush tasks are async to this
|
|
|
|
// rpc, DataNode will flush the segments in the background.
|
|
|
|
//
|
|
|
|
// Return UnexpectedError code in status:
|
|
|
|
// If DataNode isn't in HEALTHY: states not HEALTHY or dynamic checks not HEALTHY
|
|
|
|
// If DataNode doesn't find the correspounding segmentID in its memeory replica
|
|
|
|
// Return Success code in status and trigers background flush:
|
|
|
|
// Log an info log if a segment is under flushing
|
2021-03-12 06:22:09 +00:00
|
|
|
FlushSegments(ctx context.Context, req *datapb.FlushSegmentsRequest) (*commonpb.Status, error)
|
2021-09-01 02:13:15 +00:00
|
|
|
|
|
|
|
GetMetrics(ctx context.Context, req *milvuspb.GetMetricsRequest) (*milvuspb.GetMetricsResponse, error)
|
2021-03-05 07:21:33 +00:00
|
|
|
}
|
|
|
|
|
2021-10-09 02:10:59 +00:00
|
|
|
// DataNodeComponent is used by grpc server of DataNode
|
|
|
|
type DataNodeComponent interface {
|
|
|
|
DataNode
|
|
|
|
|
|
|
|
// UpdateStateCode updates state code for DataNode
|
|
|
|
// State includes: Initializing, Healthy and Abnormal
|
|
|
|
UpdateStateCode(internalpb.StateCode)
|
|
|
|
|
|
|
|
// GetStateCode return state code for DataNode
|
|
|
|
GetStateCode() internalpb.StateCode
|
|
|
|
|
|
|
|
// SetRootCoord set RootCoord for DataNode
|
|
|
|
SetRootCoord(RootCoord) error
|
|
|
|
|
|
|
|
// SetDataCoord set DataCoord for DataNode
|
|
|
|
SetDataCoord(DataCoord) error
|
|
|
|
|
|
|
|
// SetNodeID set node id for DataNode
|
|
|
|
SetNodeID(typeutil.UniqueID)
|
|
|
|
}
|
|
|
|
|
2021-09-28 14:06:06 +00:00
|
|
|
// DataCoord is the interface `datacoord` package implements
|
2021-06-21 10:22:13 +00:00
|
|
|
type DataCoord interface {
|
2021-03-05 07:21:33 +00:00
|
|
|
Component
|
|
|
|
TimeTickProvider
|
|
|
|
|
2021-09-27 02:23:57 +00:00
|
|
|
// Flush notifies DataCoord to flush all current growing segments of specified Collection
|
2021-09-28 06:14:03 +00:00
|
|
|
// ctx is the context to control request deadline and cancellation
|
2021-09-27 02:23:57 +00:00
|
|
|
// req contains the request params, which are database name(not used for now) and collection id
|
|
|
|
//
|
|
|
|
// response struct `FlushResponse` contains related db & collection meta
|
|
|
|
// and the affected segment ids
|
|
|
|
// error is returned only when some communication issue occurs
|
|
|
|
// if some error occurs in the process of `Flush`, it will be recorded and returned in `Status` field of response
|
|
|
|
//
|
|
|
|
// `Flush` returns when all growing segments of specified collection is "sealed"
|
|
|
|
// the flush procedure will wait corresponding data node(s) proceeds to the safe timestamp
|
|
|
|
// and the `Flush` operation will be truly invoked
|
|
|
|
// If the Datacoord or Datanode crashes in the flush procedure, recovery process will replay the ts check until all requirement is met
|
|
|
|
//
|
|
|
|
// Flushed segments can be check via `GetFlushedSegments` API
|
2021-06-23 08:56:11 +00:00
|
|
|
Flush(ctx context.Context, req *datapb.FlushRequest) (*datapb.FlushResponse, error)
|
2021-03-05 07:21:33 +00:00
|
|
|
|
2021-10-02 15:13:55 +00:00
|
|
|
// AssignSegmentID applies allocations for specified Coolection/Partition and related Channel Name(Virtial Channel)
|
|
|
|
//
|
|
|
|
// ctx is the context to control request deadline and cancellation
|
2021-10-03 11:42:12 +00:00
|
|
|
// req contains the requester's info(id and role) and the list of Assignment Request,
|
2021-10-02 15:13:55 +00:00
|
|
|
// which coontains the specified collection, partitaion id, the related VChannel Name and row count it needs
|
|
|
|
//
|
|
|
|
// response struct `AssignSegmentIDResponse` contains the the assignment result for each request
|
|
|
|
// error is returned only when some communication issue occurs
|
|
|
|
// if some error occurs in the process of `AssignSegmentID`, it will be recorded and returned in `Status` field of response
|
|
|
|
//
|
|
|
|
// `AssignSegmentID` will applies current configured allocation policies for each request
|
|
|
|
// if the VChannel is newly used, `WatchDmlChannels` will be invoked to notify a `DataNode`(selected by policy) to watch it
|
|
|
|
// if there is anything make the allocation impossible, the response will not contain the corresponding result
|
2021-03-12 06:22:09 +00:00
|
|
|
AssignSegmentID(ctx context.Context, req *datapb.AssignSegmentIDRequest) (*datapb.AssignSegmentIDResponse, error)
|
2021-10-03 11:42:12 +00:00
|
|
|
|
|
|
|
// GetSegmentStates requests segment state information
|
|
|
|
//
|
|
|
|
// ctx is the context to control request deadline and cancellation
|
|
|
|
// req contains the list of segment id to query
|
|
|
|
//
|
|
|
|
// response struct `GetSegmentStatesResponse` contains the list of each state query result
|
|
|
|
// when the segment is not found, the state entry will has the field `Status` to identify failure
|
|
|
|
// otherwise the Segment State and Start position information will be returned
|
|
|
|
// error is returned only when some communication issue occurs
|
2021-03-12 06:22:09 +00:00
|
|
|
GetSegmentStates(ctx context.Context, req *datapb.GetSegmentStatesRequest) (*datapb.GetSegmentStatesResponse, error)
|
2021-10-06 11:23:16 +00:00
|
|
|
|
|
|
|
// GetInsertBinlogPaths requests binlog paths for specified segment
|
|
|
|
//
|
|
|
|
// ctx is the context to control request deadline and cancellation
|
|
|
|
// req contains the segment id to query
|
|
|
|
//
|
|
|
|
// response struct `GetInsertBinlogPathsResponse` contains the fields list
|
|
|
|
// and corresponding binlog path list
|
|
|
|
// error is returned only when some communication issue occurs
|
2021-03-12 06:22:09 +00:00
|
|
|
GetInsertBinlogPaths(ctx context.Context, req *datapb.GetInsertBinlogPathsRequest) (*datapb.GetInsertBinlogPathsResponse, error)
|
2021-10-07 11:56:44 +00:00
|
|
|
|
|
|
|
// GetSegmentInfoChannel DEPRECATED
|
|
|
|
// legacy api to get SegmentInfo Channel name
|
2021-03-05 07:21:33 +00:00
|
|
|
GetSegmentInfoChannel(ctx context.Context) (*milvuspb.StringResponse, error)
|
2021-10-09 10:36:04 +00:00
|
|
|
|
|
|
|
// GetCollectionStatistics requests collection statistics
|
|
|
|
//
|
|
|
|
// ctx is the context to control request deadline and cancellation
|
|
|
|
// req contains the collection id to query
|
|
|
|
//
|
|
|
|
// response struct `GetCollectionStatisticsResponse` contains the key-value list fields returning related data
|
|
|
|
// only row count for now
|
|
|
|
// error is returned only when some communication issue occurs
|
2021-03-12 06:22:09 +00:00
|
|
|
GetCollectionStatistics(ctx context.Context, req *datapb.GetCollectionStatisticsRequest) (*datapb.GetCollectionStatisticsResponse, error)
|
|
|
|
GetPartitionStatistics(ctx context.Context, req *datapb.GetPartitionStatisticsRequest) (*datapb.GetPartitionStatisticsResponse, error)
|
|
|
|
GetSegmentInfo(ctx context.Context, req *datapb.GetSegmentInfoRequest) (*datapb.GetSegmentInfoResponse, error)
|
2021-06-07 06:16:36 +00:00
|
|
|
GetRecoveryInfo(ctx context.Context, req *datapb.GetRecoveryInfoRequest) (*datapb.GetRecoveryInfoResponse, error)
|
2021-05-27 10:45:24 +00:00
|
|
|
SaveBinlogPaths(ctx context.Context, req *datapb.SaveBinlogPathsRequest) (*commonpb.Status, error)
|
2021-07-02 03:16:20 +00:00
|
|
|
GetFlushedSegments(ctx context.Context, req *datapb.GetFlushedSegmentsRequest) (*datapb.GetFlushedSegmentsResponse, error)
|
2021-09-01 09:35:00 +00:00
|
|
|
|
|
|
|
GetMetrics(ctx context.Context, req *milvuspb.GetMetricsRequest) (*milvuspb.GetMetricsResponse, error)
|
2021-03-05 07:21:33 +00:00
|
|
|
}
|
|
|
|
|
2021-09-28 14:06:06 +00:00
|
|
|
// IndexNode is the interface `indexnode` package implements
|
2021-03-05 10:14:59 +00:00
|
|
|
type IndexNode interface {
|
2021-03-05 07:21:33 +00:00
|
|
|
Component
|
|
|
|
TimeTickProvider
|
|
|
|
|
2021-09-27 14:48:03 +00:00
|
|
|
// CreateIndex receives request from IndexCoordinator to build an index.
|
|
|
|
// Index building is asynchronous, so when an index building request comes, IndexNode records the task and returns.
|
2021-05-27 14:24:29 +00:00
|
|
|
CreateIndex(ctx context.Context, req *indexpb.CreateIndexRequest) (*commonpb.Status, error)
|
2021-09-27 14:48:03 +00:00
|
|
|
// GetMetrics gets the metrics about IndexNode.
|
2021-08-19 02:28:10 +00:00
|
|
|
GetMetrics(ctx context.Context, req *milvuspb.GetMetricsRequest) (*milvuspb.GetMetricsResponse, error)
|
2021-03-05 07:21:33 +00:00
|
|
|
}
|
|
|
|
|
2021-09-28 14:06:06 +00:00
|
|
|
// IndexCoord is the interface `indexcoord` package implements
|
2021-06-21 09:28:03 +00:00
|
|
|
type IndexCoord interface {
|
2021-03-05 07:21:33 +00:00
|
|
|
Component
|
|
|
|
TimeTickProvider
|
|
|
|
|
2021-09-27 14:48:03 +00:00
|
|
|
// BuildIndex receives request from RootCoordinator to build an index.
|
|
|
|
// Index building is asynchronous, so when an index building request comes, an IndexBuildID is assigned to the task and
|
|
|
|
// the task is recorded in Meta. The background process assignTaskLoop will find this task and assign it to IndexNode for
|
|
|
|
// execution.
|
2021-03-05 07:21:33 +00:00
|
|
|
BuildIndex(ctx context.Context, req *indexpb.BuildIndexRequest) (*indexpb.BuildIndexResponse, error)
|
2021-09-27 14:48:03 +00:00
|
|
|
// DropIndex deletes indexes based on IndexID. One IndexID corresponds to the index of an entire column. A column is
|
|
|
|
// divided into many segments, and each segment corresponds to an IndexBuildID. IndexCoord uses IndexBuildID to record
|
|
|
|
// index tasks. Therefore, when DropIndex is called, delete all tasks corresponding to IndexBuildID corresponding to IndexID.
|
2021-03-05 07:21:33 +00:00
|
|
|
DropIndex(ctx context.Context, req *indexpb.DropIndexRequest) (*commonpb.Status, error)
|
2021-09-27 14:48:03 +00:00
|
|
|
// GetIndexStates gets the index states of the IndexBuildIDs in the request from RootCoordinator.
|
2021-03-12 06:22:09 +00:00
|
|
|
GetIndexStates(ctx context.Context, req *indexpb.GetIndexStatesRequest) (*indexpb.GetIndexStatesResponse, error)
|
2021-09-27 14:48:03 +00:00
|
|
|
// GetIndexFilePaths gets the index files of the IndexBuildIDs in the request from RootCoordinator.
|
2021-03-12 06:22:09 +00:00
|
|
|
GetIndexFilePaths(ctx context.Context, req *indexpb.GetIndexFilePathsRequest) (*indexpb.GetIndexFilePathsResponse, error)
|
2021-09-27 14:48:03 +00:00
|
|
|
// GetMetrics gets the metrics about IndexCoord.
|
2021-09-01 09:35:00 +00:00
|
|
|
GetMetrics(ctx context.Context, req *milvuspb.GetMetricsRequest) (*milvuspb.GetMetricsResponse, error)
|
2021-03-05 07:21:33 +00:00
|
|
|
}
|
|
|
|
|
2021-09-28 14:06:06 +00:00
|
|
|
// RootCoord is the interface `rootcoord` package implements
|
2021-06-21 09:28:03 +00:00
|
|
|
type RootCoord interface {
|
2021-03-05 07:21:33 +00:00
|
|
|
Component
|
2021-04-24 09:23:35 +00:00
|
|
|
TimeTickProvider
|
2021-03-05 07:21:33 +00:00
|
|
|
|
2021-09-28 06:14:03 +00:00
|
|
|
// CreateCollection notifies RootCoord to create a collection
|
|
|
|
//
|
|
|
|
// ctx is the context to control request deadline and cancellation
|
|
|
|
// req contains the request params, including database name(not used), collection name, collection schema and
|
|
|
|
// physical channel num for inserting data
|
|
|
|
//
|
|
|
|
// The `ErrorCode` of `Status` is `Success` if create collection successfully;
|
|
|
|
// otherwise, the `ErrorCode` of `Status` will be `Error`, and the `Reason` of `Status` will record the fail cause.
|
|
|
|
// error is always nil
|
2021-03-12 06:22:09 +00:00
|
|
|
CreateCollection(ctx context.Context, req *milvuspb.CreateCollectionRequest) (*commonpb.Status, error)
|
2021-09-28 06:14:03 +00:00
|
|
|
|
|
|
|
// DropCollection notifies RootCoord to drop a collection
|
|
|
|
//
|
|
|
|
// ctx is the context to control request deadline and cancellation
|
|
|
|
// req contains the request params, including database name(not used) and collection name
|
|
|
|
//
|
|
|
|
// The `ErrorCode` of `Status` is `Success` if drop collection successfully;
|
|
|
|
// otherwise, the `ErrorCode` of `Status` will be `Error`, and the `Reason` of `Status` will record the fail cause.
|
|
|
|
// error is always nil
|
2021-03-12 06:22:09 +00:00
|
|
|
DropCollection(ctx context.Context, req *milvuspb.DropCollectionRequest) (*commonpb.Status, error)
|
2021-09-28 06:14:03 +00:00
|
|
|
|
|
|
|
// HasCollection notifies RootCoord to check a collection's existence at specified timestamp
|
|
|
|
//
|
|
|
|
// ctx is the context to control request deadline and cancellation
|
|
|
|
// req contains the request params, including database name(not used), collection name and timestamp
|
|
|
|
//
|
|
|
|
// The `Status` in response struct `BoolResponse` indicates if this operation is processed successfully or fail cause;
|
|
|
|
// the `Value` in `BoolResponse` is `true` if the collection exists at the specified timestamp, `false` otherwise.
|
|
|
|
// Timestamp is ignored if set to 0.
|
|
|
|
// error is always nil
|
2021-03-12 06:22:09 +00:00
|
|
|
HasCollection(ctx context.Context, req *milvuspb.HasCollectionRequest) (*milvuspb.BoolResponse, error)
|
2021-09-28 06:14:03 +00:00
|
|
|
|
|
|
|
// DescribeCollection notifies RootCoord to get all information about this collection at specified timestamp
|
|
|
|
//
|
|
|
|
// ctx is the context to control request deadline and cancellation
|
|
|
|
// req contains the request params, including database name(not used), collection name or collection id, and timestamp
|
|
|
|
//
|
|
|
|
// The `Status` in response struct `DescribeCollectionResponse` indicates if this operation is processed successfully or fail cause;
|
|
|
|
// other fields in `DescribeCollectionResponse` are filled with this collection's schema, collection id,
|
|
|
|
// physical channel names, virtual channel names, created time, alias names, and so on.
|
|
|
|
//
|
|
|
|
// If timestamp is set a non-zero value and collection does not exist at this timestamp,
|
|
|
|
// the `ErrorCode` of `Status` in `DescribeCollectionResponse` will be set to `Error`.
|
|
|
|
// Timestamp is ignored if set to 0.
|
|
|
|
// error is always nil
|
2021-03-12 06:22:09 +00:00
|
|
|
DescribeCollection(ctx context.Context, req *milvuspb.DescribeCollectionRequest) (*milvuspb.DescribeCollectionResponse, error)
|
2021-09-28 06:14:03 +00:00
|
|
|
|
2021-09-29 01:44:03 +00:00
|
|
|
// ShowCollections notifies RootCoord to list all collection names and other info in database at specified timestamp
|
2021-09-28 06:14:03 +00:00
|
|
|
//
|
|
|
|
// ctx is the context to control request deadline and cancellation
|
|
|
|
// req contains the request params, including database name(not used), collection name and timestamp
|
|
|
|
//
|
|
|
|
// The `Status` in response struct `ShowCollectionsResponse` indicates if this operation is processed successfully or fail cause;
|
2021-09-29 01:44:03 +00:00
|
|
|
// other fields in `ShowCollectionsResponse` are filled with all collection names, collection ids,
|
2021-09-28 06:14:03 +00:00
|
|
|
// created times, created UTC times, and so on.
|
|
|
|
// error is always nil
|
2021-03-12 06:22:09 +00:00
|
|
|
ShowCollections(ctx context.Context, req *milvuspb.ShowCollectionsRequest) (*milvuspb.ShowCollectionsResponse, error)
|
2021-09-29 01:44:03 +00:00
|
|
|
|
|
|
|
// CreatePartition notifies RootCoord to create a partition
|
|
|
|
//
|
|
|
|
// ctx is the context to control request deadline and cancellation
|
|
|
|
// req contains the request params, including database name(not used), collection name and partition name
|
|
|
|
//
|
|
|
|
// The `ErrorCode` of `Status` is `Success` if create partition successfully;
|
|
|
|
// otherwise, the `ErrorCode` of `Status` will be `Error`, and the `Reason` of `Status` will record the fail cause.
|
|
|
|
// error is always nil
|
2021-03-12 06:22:09 +00:00
|
|
|
CreatePartition(ctx context.Context, req *milvuspb.CreatePartitionRequest) (*commonpb.Status, error)
|
2021-09-29 01:44:03 +00:00
|
|
|
|
|
|
|
// DropPartition notifies RootCoord to drop a partition
|
|
|
|
//
|
|
|
|
// ctx is the context to control request deadline and cancellation
|
|
|
|
// req contains the request params, including database name(not used), collection name and partition name
|
|
|
|
//
|
|
|
|
// The `ErrorCode` of `Status` is `Success` if drop partition successfully;
|
|
|
|
// otherwise, the `ErrorCode` of `Status` will be `Error`, and the `Reason` of `Status` will record the fail cause.
|
|
|
|
// error is always nil
|
|
|
|
//
|
|
|
|
// Default partition cannot be dropped
|
2021-03-12 06:22:09 +00:00
|
|
|
DropPartition(ctx context.Context, req *milvuspb.DropPartitionRequest) (*commonpb.Status, error)
|
2021-09-29 01:44:03 +00:00
|
|
|
|
|
|
|
// HasPartition notifies RootCoord to check if a partition with specified name exists in the collection
|
|
|
|
//
|
|
|
|
// ctx is the context to control request deadline and cancellation
|
|
|
|
// req contains the request params, including database name(not used), collection name and partition name
|
|
|
|
//
|
|
|
|
// The `Status` in response struct `BoolResponse` indicates if this operation is processed successfully or fail cause;
|
|
|
|
// the `Value` in `BoolResponse` is `true` if the partition exists in the collection, `false` otherwise.
|
|
|
|
// error is always nil
|
2021-03-12 06:22:09 +00:00
|
|
|
HasPartition(ctx context.Context, req *milvuspb.HasPartitionRequest) (*milvuspb.BoolResponse, error)
|
2021-09-29 01:44:03 +00:00
|
|
|
|
|
|
|
// ShowPartitions notifies RootCoord to list all partition names and other info in the collection
|
|
|
|
//
|
|
|
|
// ctx is the context to control request deadline and cancellation
|
|
|
|
// req contains the request params, including database name(not used), collection name or collection id, and partition names
|
|
|
|
//
|
|
|
|
// The `Status` in response struct `ShowPartitionsResponse` indicates if this operation is processed successfully or fail cause;
|
|
|
|
// other fields in `ShowPartitionsResponse` are filled with all partition names, partition ids,
|
|
|
|
// created times, created UTC times, and so on.
|
|
|
|
// error is always nil
|
2021-03-12 06:22:09 +00:00
|
|
|
ShowPartitions(ctx context.Context, req *milvuspb.ShowPartitionsRequest) (*milvuspb.ShowPartitionsResponse, error)
|
2021-03-05 07:21:33 +00:00
|
|
|
|
2021-09-29 02:31:59 +00:00
|
|
|
// CreateIndex notifies RootCoord to create an index for the specified field in the collection
|
|
|
|
//
|
|
|
|
// ctx is the context to control request deadline and cancellation
|
|
|
|
// req contains the request params, including database name(not used), collection name, field name and index parameters
|
|
|
|
//
|
|
|
|
// The `ErrorCode` of `Status` is `Success` if create index successfully;
|
|
|
|
// otherwise, the `ErrorCode` of `Status` will be `Error`, and the `Reason` of `Status` will record the fail cause.
|
|
|
|
// error is always nil
|
2021-10-02 01:58:03 +00:00
|
|
|
//
|
|
|
|
// RootCoord forwards this request to IndexCoord to create index
|
2021-03-12 06:22:09 +00:00
|
|
|
CreateIndex(ctx context.Context, req *milvuspb.CreateIndexRequest) (*commonpb.Status, error)
|
2021-09-29 02:31:59 +00:00
|
|
|
|
|
|
|
// DescribeIndex notifies RootCoord to get specified index information for specified field
|
|
|
|
//
|
|
|
|
// ctx is the context to control request deadline and cancellation
|
|
|
|
// req contains the request params, including database name(not used), collection name, field name and index name
|
|
|
|
//
|
|
|
|
// The `Status` in response struct `DescribeIndexResponse` indicates if this operation is processed successfully or fail cause;
|
|
|
|
// index information is filled in `IndexDescriptions`
|
|
|
|
// error is always nil
|
2021-03-12 06:22:09 +00:00
|
|
|
DescribeIndex(ctx context.Context, req *milvuspb.DescribeIndexRequest) (*milvuspb.DescribeIndexResponse, error)
|
2021-09-29 02:31:59 +00:00
|
|
|
|
|
|
|
// DropIndex notifies RootCoord to drop the specified index for the specified field
|
|
|
|
//
|
|
|
|
// ctx is the context to control request deadline and cancellation
|
|
|
|
// req contains the request params, including database name(not used), collection name, field name and index name
|
|
|
|
//
|
|
|
|
// The `ErrorCode` of `Status` is `Success` if drop index successfully;
|
|
|
|
// otherwise, the `ErrorCode` of `Status` will be `Error`, and the `Reason` of `Status` will record the fail cause.
|
|
|
|
// error is always nil
|
2021-10-02 01:59:55 +00:00
|
|
|
//
|
|
|
|
// RootCoord forwards this request to IndexCoord to drop index
|
2021-03-12 06:22:09 +00:00
|
|
|
DropIndex(ctx context.Context, req *milvuspb.DropIndexRequest) (*commonpb.Status, error)
|
2021-03-05 07:21:33 +00:00
|
|
|
|
2021-09-30 16:40:08 +00:00
|
|
|
// CreateAlias notifies RootCoord to create an alias for the collection
|
|
|
|
//
|
|
|
|
// ctx is the context to control request deadline and cancellation
|
|
|
|
// req contains the request params, including collection name and alias
|
|
|
|
//
|
|
|
|
// The `ErrorCode` of `Status` is `Success` if create alias successfully;
|
|
|
|
// otherwise, the `ErrorCode` of `Status` will be `Error`, and the `Reason` of `Status` will record the fail cause.
|
|
|
|
// error is always nil
|
2021-09-18 03:13:51 +00:00
|
|
|
CreateAlias(ctx context.Context, req *milvuspb.CreateAliasRequest) (*commonpb.Status, error)
|
2021-09-30 16:44:13 +00:00
|
|
|
|
|
|
|
// DropAlias notifies RootCoord to drop an alias for the collection
|
|
|
|
//
|
|
|
|
// ctx is the context to control request deadline and cancellation
|
|
|
|
// req contains the request params, including alias
|
|
|
|
//
|
|
|
|
// The `ErrorCode` of `Status` is `Success` if drop alias successfully;
|
|
|
|
// otherwise, the `ErrorCode` of `Status` will be `Error`, and the `Reason` of `Status` will record the fail cause.
|
|
|
|
// error is always nil
|
2021-09-18 03:13:51 +00:00
|
|
|
DropAlias(ctx context.Context, req *milvuspb.DropAliasRequest) (*commonpb.Status, error)
|
2021-09-30 16:48:17 +00:00
|
|
|
|
|
|
|
// AlterAlias notifies RootCoord to alter alias for the collection
|
|
|
|
//
|
|
|
|
// ctx is the context to control request deadline and cancellation
|
|
|
|
// req contains the request params, including collection name and new alias
|
|
|
|
//
|
|
|
|
// The `ErrorCode` of `Status` is `Success` if alter alias successfully;
|
|
|
|
// otherwise, the `ErrorCode` of `Status` will be `Error`, and the `Reason` of `Status` will record the fail cause.
|
|
|
|
// error is always nil
|
2021-09-18 03:13:51 +00:00
|
|
|
AlterAlias(ctx context.Context, req *milvuspb.AlterAliasRequest) (*commonpb.Status, error)
|
|
|
|
|
2021-09-30 17:02:25 +00:00
|
|
|
// AllocTimestamp notifies RootCoord to alloc timestamps
|
|
|
|
//
|
|
|
|
// ctx is the context to control request deadline and cancellation
|
|
|
|
// req contains the count of timestamps need to be allocated
|
|
|
|
//
|
|
|
|
// The `Status` in response struct `AllocTimestampResponse` indicates if this operation is processed successfully or fail cause;
|
|
|
|
// `Timestamp` is the first available timestamp allocated
|
|
|
|
// error is always nil
|
2021-06-22 08:14:09 +00:00
|
|
|
AllocTimestamp(ctx context.Context, req *rootcoordpb.AllocTimestampRequest) (*rootcoordpb.AllocTimestampResponse, error)
|
2021-09-30 17:06:23 +00:00
|
|
|
|
|
|
|
// AllocID notifies RootCoord to alloc IDs
|
|
|
|
//
|
|
|
|
// ctx is the context to control request deadline and cancellation
|
|
|
|
// req contains the count of IDs need to be allocated
|
|
|
|
//
|
|
|
|
// The `Status` in response struct `AllocTimestampResponse` indicates if this operation is processed successfully or fail cause;
|
|
|
|
// `ID` is the first available id allocated
|
|
|
|
// error is always nil
|
2021-06-22 08:14:09 +00:00
|
|
|
AllocID(ctx context.Context, req *rootcoordpb.AllocIDRequest) (*rootcoordpb.AllocIDResponse, error)
|
2021-09-30 17:10:09 +00:00
|
|
|
|
|
|
|
// UpdateChannelTimeTick notifies RootCoord to update each Proxy's safe timestamp
|
|
|
|
//
|
|
|
|
// ctx is the context to control request deadline and cancellation
|
|
|
|
// req contains the request params, including physical channel names, channels' safe timestamps and default timestamp
|
|
|
|
//
|
|
|
|
// The `ErrorCode` of `Status` is `Success` if update channel timetick successfully;
|
|
|
|
// otherwise, the `ErrorCode` of `Status` will be `Error`, and the `Reason` of `Status` will record the fail cause.
|
|
|
|
// error is always nil
|
2021-05-21 08:08:12 +00:00
|
|
|
UpdateChannelTimeTick(ctx context.Context, req *internalpb.ChannelTimeTickMsg) (*commonpb.Status, error)
|
2021-03-05 07:21:33 +00:00
|
|
|
|
2021-09-30 17:15:38 +00:00
|
|
|
// DescribeSegment notifies RootCoord to get specified segment information in the collection
|
|
|
|
//
|
|
|
|
// ctx is the context to control request deadline and cancellation
|
|
|
|
// req contains the request params, including collection id and segment id
|
|
|
|
//
|
|
|
|
// The `Status` in response struct `DescribeSegmentResponse` indicates if this operation is processed successfully or fail cause;
|
|
|
|
// segment index information is filled in `IndexID`, `BuildID` and `EnableIndex`.
|
|
|
|
// error is always nil
|
2021-03-12 06:22:09 +00:00
|
|
|
DescribeSegment(ctx context.Context, req *milvuspb.DescribeSegmentRequest) (*milvuspb.DescribeSegmentResponse, error)
|
2021-09-30 17:18:21 +00:00
|
|
|
|
|
|
|
// ShowSegments notifies RootCoord to list all segment ids in the collection or partition
|
|
|
|
//
|
|
|
|
// ctx is the context to control request deadline and cancellation
|
|
|
|
// req contains the request params, including collection id and partition id
|
|
|
|
//
|
|
|
|
// The `Status` in response struct `ShowSegmentsResponse` indicates if this operation is processed successfully or fail cause;
|
|
|
|
// `SegmentIDs` in `ShowSegmentsResponse` records all segment ids.
|
|
|
|
// error is always nil
|
2021-03-12 06:22:09 +00:00
|
|
|
ShowSegments(ctx context.Context, req *milvuspb.ShowSegmentsRequest) (*milvuspb.ShowSegmentsResponse, error)
|
2021-10-02 01:06:07 +00:00
|
|
|
|
|
|
|
// ReleaseDQLMessageStream notifies RootCoord to release and close the search message stream of specific collection.
|
|
|
|
//
|
|
|
|
// ctx is the request to control request deadline and cancellation.
|
|
|
|
// request contains the request params, which are database id(not used) and collection id.
|
|
|
|
//
|
|
|
|
// The `ErrorCode` of `Status` is `Success` if drop index successfully;
|
|
|
|
// otherwise, the `ErrorCode` of `Status` will be `Error`, and the `Reason` of `Status` will record the fail cause.
|
|
|
|
// error is always nil
|
|
|
|
//
|
|
|
|
// RootCoord just forwards this request to Proxy client
|
2021-06-17 09:45:56 +00:00
|
|
|
ReleaseDQLMessageStream(ctx context.Context, in *proxypb.ReleaseDQLMessageStreamRequest) (*commonpb.Status, error)
|
2021-10-02 01:08:46 +00:00
|
|
|
|
|
|
|
// SegmentFlushCompleted notifies RootCoord that specified segment has been flushed
|
|
|
|
//
|
|
|
|
// ctx is the context to control request deadline and cancellation
|
|
|
|
// req contains the request params, including SegmentInfo
|
|
|
|
//
|
|
|
|
// The `ErrorCode` of `Status` is `Success` if process successfully;
|
|
|
|
// otherwise, the `ErrorCode` of `Status` will be `Error`, and the `Reason` of `Status` will record the fail cause.
|
|
|
|
// error is always nil
|
|
|
|
//
|
|
|
|
// This interface is only used by DataCoord, when RootCoord receives this request, RootCoord will notify IndexCoord
|
|
|
|
// to build index for this segment.
|
2021-07-02 03:16:20 +00:00
|
|
|
SegmentFlushCompleted(ctx context.Context, in *datapb.SegmentFlushCompletedMsg) (*commonpb.Status, error)
|
2021-09-01 09:35:00 +00:00
|
|
|
|
2021-10-02 01:12:03 +00:00
|
|
|
// GetMetrics notifies RootCoord to collect metrics for specified component
|
2021-09-01 09:35:00 +00:00
|
|
|
GetMetrics(ctx context.Context, req *milvuspb.GetMetricsRequest) (*milvuspb.GetMetricsResponse, error)
|
2021-03-05 07:21:33 +00:00
|
|
|
}
|
|
|
|
|
2021-06-22 11:08:03 +00:00
|
|
|
// RootCoordComponent is used by grpc server of RootCoord
|
2021-06-21 09:28:03 +00:00
|
|
|
type RootCoordComponent interface {
|
|
|
|
RootCoord
|
2021-04-24 09:23:35 +00:00
|
|
|
|
2021-10-02 01:18:28 +00:00
|
|
|
// UpdateStateCode updates state code for RootCoord
|
|
|
|
// State includes: Initializing, Healthy and Abnormal
|
2021-04-24 09:23:35 +00:00
|
|
|
UpdateStateCode(internalpb.StateCode)
|
2021-10-02 01:22:25 +00:00
|
|
|
|
|
|
|
// SetDataCoord set DataCoord for RootCoord
|
2021-06-21 10:22:13 +00:00
|
|
|
SetDataCoord(context.Context, DataCoord) error
|
2021-10-02 01:26:24 +00:00
|
|
|
|
|
|
|
// SetIndexCoord set IndexCoord for RootCoord
|
2021-06-21 09:28:03 +00:00
|
|
|
SetIndexCoord(IndexCoord) error
|
2021-10-02 01:30:27 +00:00
|
|
|
|
|
|
|
// SetQueryCoord set QueryCoord for RootCoord
|
2021-06-22 08:44:09 +00:00
|
|
|
SetQueryCoord(QueryCoord) error
|
2021-10-02 01:34:27 +00:00
|
|
|
|
|
|
|
// SetNewProxyClient set Proxy client creator func for RootCoord
|
2021-06-22 11:08:03 +00:00
|
|
|
SetNewProxyClient(func(sess *sessionutil.Session) (Proxy, error))
|
2021-08-31 03:45:59 +00:00
|
|
|
|
2021-10-02 01:14:14 +00:00
|
|
|
// GetMetrics notifies RootCoordComponent to collect metrics for specified component
|
2021-08-31 03:45:59 +00:00
|
|
|
GetMetrics(ctx context.Context, req *milvuspb.GetMetricsRequest) (*milvuspb.GetMetricsResponse, error)
|
2021-04-24 09:23:35 +00:00
|
|
|
}
|
|
|
|
|
2021-09-28 14:06:06 +00:00
|
|
|
// Proxy is the interface `proxy` package implements
|
2021-06-22 11:08:03 +00:00
|
|
|
type Proxy interface {
|
2021-03-05 07:21:33 +00:00
|
|
|
Component
|
|
|
|
|
2021-09-27 10:23:59 +00:00
|
|
|
// InvalidateCollectionMetaCache notifies Proxy to clear all the meta cache of specific collection.
|
|
|
|
//
|
|
|
|
// InvalidateCollectionMetaCache should be called when there are any meta changes in specific collection.
|
|
|
|
// Such as `DropCollection`, `CreatePartition`, `DropPartition`, etc.
|
|
|
|
//
|
|
|
|
// ctx is the request to control request deadline and cancellation.
|
|
|
|
// request contains the request params, which are database name(not used now) and collection name.
|
|
|
|
//
|
|
|
|
// InvalidateCollectionMetaCache should always succeed even though the specific collection doesn't exist in Proxy.
|
|
|
|
// So the code of response `Status` should be always `Success`.
|
|
|
|
//
|
|
|
|
// error is returned only when some communication issue occurs.
|
2021-03-05 07:21:33 +00:00
|
|
|
InvalidateCollectionMetaCache(ctx context.Context, request *proxypb.InvalidateCollMetaCacheRequest) (*commonpb.Status, error)
|
2021-09-27 10:23:59 +00:00
|
|
|
|
|
|
|
// ReleaseDQLMessageStream notifies Proxy to release and close the search message stream of specific collection.
|
|
|
|
//
|
|
|
|
// ReleaseDQLMessageStream should be called when the specific collection was released.
|
|
|
|
//
|
|
|
|
// ctx is the request to control request deadline and cancellation.
|
|
|
|
// request contains the request params, which are database id(not used now) and collection id.
|
|
|
|
//
|
|
|
|
// ReleaseDQLMessageStream should always succeed even though the specific collection doesn't exist in Proxy.
|
|
|
|
// So the code of response `Status` should be always `Success`.
|
|
|
|
//
|
|
|
|
// error is returned only when some communication issue occurs.
|
2021-06-17 09:45:56 +00:00
|
|
|
ReleaseDQLMessageStream(ctx context.Context, in *proxypb.ReleaseDQLMessageStreamRequest) (*commonpb.Status, error)
|
2021-03-05 07:21:33 +00:00
|
|
|
}
|
|
|
|
|
2021-09-28 14:06:06 +00:00
|
|
|
// QueryNode is the interface `querynode` package implements
|
2021-03-05 10:14:59 +00:00
|
|
|
type QueryNode interface {
|
2021-03-05 07:21:33 +00:00
|
|
|
Component
|
|
|
|
TimeTickProvider
|
|
|
|
|
2021-09-29 15:32:38 +00:00
|
|
|
// AddQueryChannel notifies QueryNode to subscribe a query channel and be a producer of a query result channel.
|
|
|
|
// `ctx` is the context to control request deadline and cancellation.
|
|
|
|
// `req` contains the request params, which are collection id, query channel and query result channel.
|
|
|
|
//
|
|
|
|
// Return UnexpectedError code in status:
|
|
|
|
// If QueryNode isn't in HEALTHY: states not HEALTHY or dynamic checks not HEALTHY.
|
|
|
|
// Return Success code in status:
|
|
|
|
// Subscribe a query channel and be a producer of a query result channel.
|
2021-03-12 06:22:09 +00:00
|
|
|
AddQueryChannel(ctx context.Context, req *querypb.AddQueryChannelRequest) (*commonpb.Status, error)
|
|
|
|
RemoveQueryChannel(ctx context.Context, req *querypb.RemoveQueryChannelRequest) (*commonpb.Status, error)
|
|
|
|
WatchDmChannels(ctx context.Context, req *querypb.WatchDmChannelsRequest) (*commonpb.Status, error)
|
2021-10-01 01:49:34 +00:00
|
|
|
// LoadSegments notifies QueryNode to load the sealed segments from storage. The load tasks are sync to this
|
|
|
|
// rpc, QueryNode will return after all the sealed segments are loaded.
|
|
|
|
//
|
|
|
|
// Return UnexpectedError code in status:
|
|
|
|
// If QueryNode isn't in HEALTHY: states not HEALTHY or dynamic checks not HEALTHY.
|
|
|
|
// If any segment is loaded failed in QueryNode.
|
|
|
|
// Return Success code in status:
|
|
|
|
// All the sealed segments are loaded.
|
2021-03-12 06:22:09 +00:00
|
|
|
LoadSegments(ctx context.Context, req *querypb.LoadSegmentsRequest) (*commonpb.Status, error)
|
|
|
|
ReleaseCollection(ctx context.Context, req *querypb.ReleaseCollectionRequest) (*commonpb.Status, error)
|
|
|
|
ReleasePartitions(ctx context.Context, req *querypb.ReleasePartitionsRequest) (*commonpb.Status, error)
|
|
|
|
ReleaseSegments(ctx context.Context, req *querypb.ReleaseSegmentsRequest) (*commonpb.Status, error)
|
|
|
|
GetSegmentInfo(ctx context.Context, req *querypb.GetSegmentInfoRequest) (*querypb.GetSegmentInfoResponse, error)
|
2021-08-17 02:06:11 +00:00
|
|
|
|
|
|
|
GetMetrics(ctx context.Context, req *milvuspb.GetMetricsRequest) (*milvuspb.GetMetricsResponse, error)
|
2021-03-05 07:21:33 +00:00
|
|
|
}
|
|
|
|
|
2021-09-28 14:06:06 +00:00
|
|
|
// QueryCoord is the interface `querycoord` package implements
|
2021-06-22 08:44:09 +00:00
|
|
|
type QueryCoord interface {
|
2021-03-05 07:21:33 +00:00
|
|
|
Component
|
|
|
|
TimeTickProvider
|
|
|
|
|
2021-03-12 06:22:09 +00:00
|
|
|
ShowCollections(ctx context.Context, req *querypb.ShowCollectionsRequest) (*querypb.ShowCollectionsResponse, error)
|
2021-03-05 07:21:33 +00:00
|
|
|
LoadCollection(ctx context.Context, req *querypb.LoadCollectionRequest) (*commonpb.Status, error)
|
|
|
|
ReleaseCollection(ctx context.Context, req *querypb.ReleaseCollectionRequest) (*commonpb.Status, error)
|
2021-03-12 06:22:09 +00:00
|
|
|
ShowPartitions(ctx context.Context, req *querypb.ShowPartitionsRequest) (*querypb.ShowPartitionsResponse, error)
|
|
|
|
LoadPartitions(ctx context.Context, req *querypb.LoadPartitionsRequest) (*commonpb.Status, error)
|
|
|
|
ReleasePartitions(ctx context.Context, req *querypb.ReleasePartitionsRequest) (*commonpb.Status, error)
|
2021-06-15 04:41:40 +00:00
|
|
|
CreateQueryChannel(ctx context.Context, req *querypb.CreateQueryChannelRequest) (*querypb.CreateQueryChannelResponse, error)
|
2021-03-12 06:22:09 +00:00
|
|
|
GetPartitionStates(ctx context.Context, req *querypb.GetPartitionStatesRequest) (*querypb.GetPartitionStatesResponse, error)
|
|
|
|
GetSegmentInfo(ctx context.Context, req *querypb.GetSegmentInfoRequest) (*querypb.GetSegmentInfoResponse, error)
|
2021-08-17 02:06:11 +00:00
|
|
|
|
|
|
|
GetMetrics(ctx context.Context, req *milvuspb.GetMetricsRequest) (*milvuspb.GetMetricsResponse, error)
|
2021-03-05 07:21:33 +00:00
|
|
|
}
|
2021-10-11 02:02:25 +00:00
|
|
|
|
|
|
|
// QueryCoordComponent is used by grpc server of QueryCoord
|
|
|
|
type QueryCoordComponent interface {
|
|
|
|
QueryCoord
|
|
|
|
|
|
|
|
// UpdateStateCode updates state code for QueryCoord
|
|
|
|
// State includes: Initializing, Healthy and Abnormal
|
|
|
|
UpdateStateCode(internalpb.StateCode)
|
|
|
|
|
|
|
|
// SetDataCoord set DataCoord for QueryCoord
|
|
|
|
SetDataCoord(DataCoord)
|
|
|
|
|
|
|
|
// SetRootCoord set RootCoord for QueryCoord
|
|
|
|
SetRootCoord(RootCoord)
|
|
|
|
}
|