2021-01-19 03:37:16 +00:00
|
|
|
package datanode
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"fmt"
|
|
|
|
"reflect"
|
|
|
|
|
2021-02-26 02:13:36 +00:00
|
|
|
"go.uber.org/zap"
|
|
|
|
|
2021-01-25 10:33:10 +00:00
|
|
|
"github.com/zilliztech/milvus-distributed/internal/errors"
|
2021-02-26 02:13:36 +00:00
|
|
|
"github.com/zilliztech/milvus-distributed/internal/log"
|
2021-01-25 10:33:10 +00:00
|
|
|
"github.com/zilliztech/milvus-distributed/internal/proto/commonpb"
|
2021-01-19 03:37:16 +00:00
|
|
|
"github.com/zilliztech/milvus-distributed/internal/proto/etcdpb"
|
2021-01-25 10:33:10 +00:00
|
|
|
"github.com/zilliztech/milvus-distributed/internal/proto/milvuspb"
|
2021-01-19 03:37:16 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
type metaService struct {
|
2021-01-25 10:33:10 +00:00
|
|
|
ctx context.Context
|
2021-02-04 12:31:23 +00:00
|
|
|
replica Replica
|
2021-01-25 10:33:10 +00:00
|
|
|
masterClient MasterServiceInterface
|
2021-01-19 03:37:16 +00:00
|
|
|
}
|
|
|
|
|
2021-02-04 12:31:23 +00:00
|
|
|
func newMetaService(ctx context.Context, replica Replica, m MasterServiceInterface) *metaService {
|
2021-01-19 03:37:16 +00:00
|
|
|
return &metaService{
|
2021-01-25 10:33:10 +00:00
|
|
|
ctx: ctx,
|
|
|
|
replica: replica,
|
|
|
|
masterClient: m,
|
2021-01-19 03:37:16 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-01-25 10:33:10 +00:00
|
|
|
func (mService *metaService) init() {
|
2021-02-26 02:13:36 +00:00
|
|
|
log.Debug("Initing meta ...")
|
2021-01-19 03:37:16 +00:00
|
|
|
err := mService.loadCollections()
|
|
|
|
if err != nil {
|
2021-02-26 02:13:36 +00:00
|
|
|
log.Error("metaService init failed", zap.Error(err))
|
2021-01-19 03:37:16 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-01-25 10:33:10 +00:00
|
|
|
func (mService *metaService) loadCollections() error {
|
|
|
|
names, err := mService.getCollectionNames()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2021-01-19 03:37:16 +00:00
|
|
|
|
2021-01-25 10:33:10 +00:00
|
|
|
for _, name := range names {
|
|
|
|
err := mService.createCollection(name)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil
|
2021-01-19 03:37:16 +00:00
|
|
|
}
|
|
|
|
|
2021-01-25 10:33:10 +00:00
|
|
|
func (mService *metaService) getCollectionNames() ([]string, error) {
|
|
|
|
req := &milvuspb.ShowCollectionRequest{
|
|
|
|
Base: &commonpb.MsgBase{
|
|
|
|
MsgType: commonpb.MsgType_kShowCollections,
|
|
|
|
MsgID: 0, //GOOSE TODO
|
|
|
|
Timestamp: 0, // GOOSE TODO
|
|
|
|
SourceID: Params.NodeID,
|
|
|
|
},
|
|
|
|
DbName: "default", // GOOSE TODO
|
|
|
|
}
|
2021-01-25 07:16:28 +00:00
|
|
|
|
2021-01-25 10:33:10 +00:00
|
|
|
response, err := mService.masterClient.ShowCollections(req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, errors.Errorf("Get collection names from master service wrong: %v", err)
|
|
|
|
}
|
|
|
|
return response.GetCollectionNames(), nil
|
2021-01-19 03:37:16 +00:00
|
|
|
}
|
|
|
|
|
2021-01-25 10:33:10 +00:00
|
|
|
func (mService *metaService) createCollection(name string) error {
|
2021-02-26 02:13:36 +00:00
|
|
|
log.Debug("Describing collections")
|
2021-01-25 10:33:10 +00:00
|
|
|
req := &milvuspb.DescribeCollectionRequest{
|
|
|
|
Base: &commonpb.MsgBase{
|
|
|
|
MsgType: commonpb.MsgType_kDescribeCollection,
|
|
|
|
MsgID: 0, //GOOSE TODO
|
|
|
|
Timestamp: 0, // GOOSE TODO
|
|
|
|
SourceID: Params.NodeID,
|
|
|
|
},
|
|
|
|
DbName: "default", // GOOSE TODO
|
|
|
|
CollectionName: name,
|
|
|
|
}
|
2021-01-19 03:37:16 +00:00
|
|
|
|
2021-01-25 10:33:10 +00:00
|
|
|
response, err := mService.masterClient.DescribeCollection(req)
|
|
|
|
if err != nil {
|
|
|
|
return errors.Errorf("Describe collection %v from master service wrong: %v", name, err)
|
|
|
|
}
|
2021-01-19 03:37:16 +00:00
|
|
|
|
2021-01-25 10:33:10 +00:00
|
|
|
err = mService.replica.addCollection(response.GetCollectionID(), response.GetSchema())
|
|
|
|
if err != nil {
|
|
|
|
return errors.Errorf("Add collection %v into collReplica wrong: %v", name, err)
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
2021-01-19 03:37:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func printCollectionStruct(obj *etcdpb.CollectionMeta) {
|
|
|
|
v := reflect.ValueOf(obj)
|
|
|
|
v = reflect.Indirect(v)
|
|
|
|
typeOfS := v.Type()
|
|
|
|
|
|
|
|
for i := 0; i < v.NumField(); i++ {
|
|
|
|
if typeOfS.Field(i).Name == "GrpcMarshalString" {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
fmt.Printf("Field: %s\tValue: %v\n", typeOfS.Field(i).Name, v.Field(i).Interface())
|
|
|
|
}
|
|
|
|
}
|