mirror of https://github.com/milvus-io/milvus.git
Fix the bug of meta cache in Proxy
Signed-off-by: dragondriver <jiquan.long@zilliz.com>pull/4973/head^2
parent
c1fbc4f8fa
commit
84b15c1f5c
|
@ -31,6 +31,8 @@ ParseVecNode(Plan* plan, const Json& out_body) {
|
||||||
std::string field_name = iter.key();
|
std::string field_name = iter.key();
|
||||||
auto& vec_info = iter.value();
|
auto& vec_info = iter.value();
|
||||||
auto topK = vec_info["topk"];
|
auto topK = vec_info["topk"];
|
||||||
|
AssertInfo(topK > 0, "topK must greater than 0");
|
||||||
|
AssertInfo(topK < 16384, "topK is too large");
|
||||||
vec_node->query_info_.topK_ = topK;
|
vec_node->query_info_.topK_ = topK;
|
||||||
vec_node->query_info_.metric_type_ = vec_info["metric_type"];
|
vec_node->query_info_.metric_type_ = vec_info["metric_type"];
|
||||||
vec_node->query_info_.search_params_ = vec_info["params"];
|
vec_node->query_info_.search_params_ = vec_info["params"];
|
||||||
|
|
|
@ -4,30 +4,26 @@ import (
|
||||||
"context"
|
"context"
|
||||||
"sync"
|
"sync"
|
||||||
|
|
||||||
"github.com/zilliztech/milvus-distributed/internal/allocator"
|
|
||||||
"github.com/zilliztech/milvus-distributed/internal/errors"
|
"github.com/zilliztech/milvus-distributed/internal/errors"
|
||||||
"github.com/zilliztech/milvus-distributed/internal/proto/internalpb"
|
"github.com/zilliztech/milvus-distributed/internal/proto/internalpb"
|
||||||
"github.com/zilliztech/milvus-distributed/internal/proto/masterpb"
|
|
||||||
"github.com/zilliztech/milvus-distributed/internal/proto/servicepb"
|
"github.com/zilliztech/milvus-distributed/internal/proto/servicepb"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Cache interface {
|
type Cache interface {
|
||||||
Hit(collectionName string) bool
|
Hit(collectionName string) bool
|
||||||
Get(collectionName string) (*servicepb.CollectionDescription, error)
|
Get(collectionName string) (*servicepb.CollectionDescription, error)
|
||||||
Update(collectionName string) error
|
Sync(collectionName string) error
|
||||||
|
Update(collectionName string, desc *servicepb.CollectionDescription) error
|
||||||
Remove(collectionName string) error
|
Remove(collectionName string) error
|
||||||
}
|
}
|
||||||
|
|
||||||
var globalMetaCache Cache
|
var globalMetaCache Cache
|
||||||
|
|
||||||
type SimpleMetaCache struct {
|
type SimpleMetaCache struct {
|
||||||
mu sync.RWMutex
|
mu sync.RWMutex
|
||||||
proxyID UniqueID
|
metas map[string]*servicepb.CollectionDescription // collection name to schema
|
||||||
metas map[string]*servicepb.CollectionDescription // collection name to schema
|
ctx context.Context
|
||||||
masterClient masterpb.MasterClient
|
proxyInstance *Proxy
|
||||||
reqIDAllocator *allocator.IDAllocator
|
|
||||||
tsoAllocator *allocator.TimestampAllocator
|
|
||||||
ctx context.Context
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (metaCache *SimpleMetaCache) Hit(collectionName string) bool {
|
func (metaCache *SimpleMetaCache) Hit(collectionName string) bool {
|
||||||
|
@ -47,58 +43,34 @@ func (metaCache *SimpleMetaCache) Get(collectionName string) (*servicepb.Collect
|
||||||
return schema, nil
|
return schema, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (metaCache *SimpleMetaCache) Update(collectionName string) error {
|
func (metaCache *SimpleMetaCache) Sync(collectionName string) error {
|
||||||
reqID, err := metaCache.reqIDAllocator.AllocOne()
|
dct := &DescribeCollectionTask{
|
||||||
if err != nil {
|
Condition: NewTaskCondition(metaCache.ctx),
|
||||||
return err
|
DescribeCollectionRequest: internalpb.DescribeCollectionRequest{
|
||||||
}
|
MsgType: internalpb.MsgType_kDescribeCollection,
|
||||||
ts, err := metaCache.tsoAllocator.AllocOne()
|
CollectionName: &servicepb.CollectionName{
|
||||||
if err != nil {
|
CollectionName: collectionName,
|
||||||
return err
|
},
|
||||||
}
|
|
||||||
hasCollectionReq := &internalpb.HasCollectionRequest{
|
|
||||||
MsgType: internalpb.MsgType_kHasCollection,
|
|
||||||
ReqID: reqID,
|
|
||||||
Timestamp: ts,
|
|
||||||
ProxyID: metaCache.proxyID,
|
|
||||||
CollectionName: &servicepb.CollectionName{
|
|
||||||
CollectionName: collectionName,
|
|
||||||
},
|
},
|
||||||
|
masterClient: metaCache.proxyInstance.masterClient,
|
||||||
}
|
}
|
||||||
has, err := metaCache.masterClient.HasCollection(metaCache.ctx, hasCollectionReq)
|
var cancel func()
|
||||||
if err != nil {
|
dct.ctx, cancel = context.WithTimeout(metaCache.ctx, reqTimeoutInterval)
|
||||||
return err
|
defer cancel()
|
||||||
}
|
|
||||||
if !has.Value {
|
|
||||||
return errors.New("collection " + collectionName + " not exists")
|
|
||||||
}
|
|
||||||
|
|
||||||
reqID, err = metaCache.reqIDAllocator.AllocOne()
|
err := metaCache.proxyInstance.sched.DdQueue.Enqueue(dct)
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
ts, err = metaCache.tsoAllocator.AllocOne()
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
req := &internalpb.DescribeCollectionRequest{
|
|
||||||
MsgType: internalpb.MsgType_kDescribeCollection,
|
|
||||||
ReqID: reqID,
|
|
||||||
Timestamp: ts,
|
|
||||||
ProxyID: metaCache.proxyID,
|
|
||||||
CollectionName: &servicepb.CollectionName{
|
|
||||||
CollectionName: collectionName,
|
|
||||||
},
|
|
||||||
}
|
|
||||||
resp, err := metaCache.masterClient.DescribeCollection(metaCache.ctx, req)
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return dct.WaitToFinish()
|
||||||
|
}
|
||||||
|
|
||||||
|
func (metaCache *SimpleMetaCache) Update(collectionName string, desc *servicepb.CollectionDescription) error {
|
||||||
metaCache.mu.Lock()
|
metaCache.mu.Lock()
|
||||||
defer metaCache.mu.Unlock()
|
defer metaCache.mu.Unlock()
|
||||||
metaCache.metas[collectionName] = resp
|
|
||||||
|
|
||||||
|
metaCache.metas[collectionName] = desc
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -115,23 +87,14 @@ func (metaCache *SimpleMetaCache) Remove(collectionName string) error {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func newSimpleMetaCache(ctx context.Context,
|
func newSimpleMetaCache(ctx context.Context, proxyInstance *Proxy) *SimpleMetaCache {
|
||||||
mCli masterpb.MasterClient,
|
|
||||||
idAllocator *allocator.IDAllocator,
|
|
||||||
tsoAllocator *allocator.TimestampAllocator) *SimpleMetaCache {
|
|
||||||
return &SimpleMetaCache{
|
return &SimpleMetaCache{
|
||||||
metas: make(map[string]*servicepb.CollectionDescription),
|
metas: make(map[string]*servicepb.CollectionDescription),
|
||||||
masterClient: mCli,
|
proxyInstance: proxyInstance,
|
||||||
reqIDAllocator: idAllocator,
|
ctx: ctx,
|
||||||
tsoAllocator: tsoAllocator,
|
|
||||||
proxyID: Params.ProxyID(),
|
|
||||||
ctx: ctx,
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func initGlobalMetaCache(ctx context.Context,
|
func initGlobalMetaCache(ctx context.Context, proxyInstance *Proxy) {
|
||||||
mCli masterpb.MasterClient,
|
globalMetaCache = newSimpleMetaCache(ctx, proxyInstance)
|
||||||
idAllocator *allocator.IDAllocator,
|
|
||||||
tsoAllocator *allocator.TimestampAllocator) {
|
|
||||||
globalMetaCache = newSimpleMetaCache(ctx, mCli, idAllocator, tsoAllocator)
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -109,7 +109,7 @@ func (p *Proxy) startProxy() error {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
initGlobalMetaCache(p.proxyLoopCtx, p.masterClient, p.idAllocator, p.tsoAllocator)
|
initGlobalMetaCache(p.proxyLoopCtx, p)
|
||||||
p.manipulationMsgStream.Start()
|
p.manipulationMsgStream.Start()
|
||||||
p.queryMsgStream.Start()
|
p.queryMsgStream.Start()
|
||||||
p.sched.Start()
|
p.sched.Start()
|
||||||
|
|
|
@ -91,7 +91,7 @@ func (it *InsertTask) PreExecute() error {
|
||||||
func (it *InsertTask) Execute() error {
|
func (it *InsertTask) Execute() error {
|
||||||
collectionName := it.BaseInsertTask.CollectionName
|
collectionName := it.BaseInsertTask.CollectionName
|
||||||
if !globalMetaCache.Hit(collectionName) {
|
if !globalMetaCache.Hit(collectionName) {
|
||||||
err := globalMetaCache.Update(collectionName)
|
err := globalMetaCache.Sync(collectionName)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -352,7 +352,7 @@ func (qt *QueryTask) SetTs(ts Timestamp) {
|
||||||
func (qt *QueryTask) PreExecute() error {
|
func (qt *QueryTask) PreExecute() error {
|
||||||
collectionName := qt.query.CollectionName
|
collectionName := qt.query.CollectionName
|
||||||
if !globalMetaCache.Hit(collectionName) {
|
if !globalMetaCache.Hit(collectionName) {
|
||||||
err := globalMetaCache.Update(collectionName)
|
err := globalMetaCache.Sync(collectionName)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -605,14 +605,9 @@ func (dct *DescribeCollectionTask) PreExecute() error {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (dct *DescribeCollectionTask) Execute() error {
|
func (dct *DescribeCollectionTask) Execute() error {
|
||||||
if !globalMetaCache.Hit(dct.CollectionName.CollectionName) {
|
|
||||||
err := globalMetaCache.Update(dct.CollectionName.CollectionName)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
var err error
|
var err error
|
||||||
dct.result, err = globalMetaCache.Get(dct.CollectionName.CollectionName)
|
dct.result, err = dct.masterClient.DescribeCollection(dct.ctx, &dct.DescribeCollectionRequest)
|
||||||
|
globalMetaCache.Update(dct.CollectionName.CollectionName, dct.result)
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -29,7 +29,7 @@ func createPlan(col Collection, dsl string) (*Plan, error) {
|
||||||
if errorCode != 0 {
|
if errorCode != 0 {
|
||||||
errorMsg := C.GoString(status.error_msg)
|
errorMsg := C.GoString(status.error_msg)
|
||||||
defer C.free(unsafe.Pointer(status.error_msg))
|
defer C.free(unsafe.Pointer(status.error_msg))
|
||||||
return nil, errors.New("Insert failed, C runtime error detected, error code = " + strconv.Itoa(int(errorCode)) + ", error msg = " + errorMsg)
|
return nil, errors.New("Create plan failed, C runtime error detected, error code = " + strconv.Itoa(int(errorCode)) + ", error msg = " + errorMsg)
|
||||||
}
|
}
|
||||||
|
|
||||||
var newPlan = &Plan{cPlan: cPlan}
|
var newPlan = &Plan{cPlan: cPlan}
|
||||||
|
@ -60,7 +60,7 @@ func parserPlaceholderGroup(plan *Plan, placeHolderBlob []byte) (*PlaceholderGro
|
||||||
if errorCode != 0 {
|
if errorCode != 0 {
|
||||||
errorMsg := C.GoString(status.error_msg)
|
errorMsg := C.GoString(status.error_msg)
|
||||||
defer C.free(unsafe.Pointer(status.error_msg))
|
defer C.free(unsafe.Pointer(status.error_msg))
|
||||||
return nil, errors.New("Insert failed, C runtime error detected, error code = " + strconv.Itoa(int(errorCode)) + ", error msg = " + errorMsg)
|
return nil, errors.New("Parser placeholder group failed, C runtime error detected, error code = " + strconv.Itoa(int(errorCode)) + ", error msg = " + errorMsg)
|
||||||
}
|
}
|
||||||
|
|
||||||
var newPlaceholderGroup = &PlaceholderGroup{cPlaceholderGroup: cPlaceholderGroup}
|
var newPlaceholderGroup = &PlaceholderGroup{cPlaceholderGroup: cPlaceholderGroup}
|
||||||
|
|
|
@ -139,7 +139,7 @@ func (ss *searchService) receiveSearchMsg() {
|
||||||
err := ss.search(msg)
|
err := ss.search(msg)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Println(err)
|
log.Println(err)
|
||||||
err = ss.publishFailedSearchResult(msg)
|
err = ss.publishFailedSearchResult(msg, err.Error())
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Println("publish FailedSearchResult failed, error message: ", err)
|
log.Println("publish FailedSearchResult failed, error message: ", err)
|
||||||
}
|
}
|
||||||
|
@ -191,7 +191,7 @@ func (ss *searchService) doUnsolvedMsgSearch() {
|
||||||
err := ss.search(msg)
|
err := ss.search(msg)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Println(err)
|
log.Println(err)
|
||||||
err = ss.publishFailedSearchResult(msg)
|
err = ss.publishFailedSearchResult(msg, err.Error())
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Println("publish FailedSearchResult failed, error message: ", err)
|
log.Println("publish FailedSearchResult failed, error message: ", err)
|
||||||
}
|
}
|
||||||
|
@ -346,7 +346,7 @@ func (ss *searchService) publishSearchResult(msg msgstream.TsMsg) error {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (ss *searchService) publishFailedSearchResult(msg msgstream.TsMsg) error {
|
func (ss *searchService) publishFailedSearchResult(msg msgstream.TsMsg, errMsg string) error {
|
||||||
msgPack := msgstream.MsgPack{}
|
msgPack := msgstream.MsgPack{}
|
||||||
searchMsg, ok := msg.(*msgstream.SearchMsg)
|
searchMsg, ok := msg.(*msgstream.SearchMsg)
|
||||||
if !ok {
|
if !ok {
|
||||||
|
@ -354,7 +354,7 @@ func (ss *searchService) publishFailedSearchResult(msg msgstream.TsMsg) error {
|
||||||
}
|
}
|
||||||
var results = internalpb.SearchResult{
|
var results = internalpb.SearchResult{
|
||||||
MsgType: internalpb.MsgType_kSearchResult,
|
MsgType: internalpb.MsgType_kSearchResult,
|
||||||
Status: &commonpb.Status{ErrorCode: commonpb.ErrorCode_UNEXPECTED_ERROR},
|
Status: &commonpb.Status{ErrorCode: commonpb.ErrorCode_UNEXPECTED_ERROR, Reason: errMsg},
|
||||||
ReqID: searchMsg.ReqID,
|
ReqID: searchMsg.ReqID,
|
||||||
ProxyID: searchMsg.ProxyID,
|
ProxyID: searchMsg.ProxyID,
|
||||||
QueryNodeID: searchMsg.ProxyID,
|
QueryNodeID: searchMsg.ProxyID,
|
||||||
|
|
Loading…
Reference in New Issue