mirror of https://github.com/milvus-io/milvus.git
Workaround fix ChannelManager holding mutex too long (#26870)
Signed-off-by: longjiquan <jiquan.long@zilliz.com>pull/26878/head
parent
9b3e744b24
commit
61c7b0990d
|
@ -366,7 +366,7 @@ func trimSegmentInfo(info *datapb.SegmentInfo) *datapb.SegmentInfo {
|
||||||
// HasCollection returns whether the collection exist from user's perspective.
|
// HasCollection returns whether the collection exist from user's perspective.
|
||||||
func (h *ServerHandler) HasCollection(ctx context.Context, collectionID UniqueID) (bool, error) {
|
func (h *ServerHandler) HasCollection(ctx context.Context, collectionID UniqueID) (bool, error) {
|
||||||
var hasCollection bool
|
var hasCollection bool
|
||||||
ctx2, cancel := context.WithTimeout(ctx, time.Minute*30)
|
ctx2, cancel := context.WithTimeout(ctx, time.Second*10)
|
||||||
defer cancel()
|
defer cancel()
|
||||||
if err := retry.Do(ctx2, func() error {
|
if err := retry.Do(ctx2, func() error {
|
||||||
has, err := h.s.broker.HasCollection(ctx2, collectionID)
|
has, err := h.s.broker.HasCollection(ctx2, collectionID)
|
||||||
|
@ -376,9 +376,13 @@ func (h *ServerHandler) HasCollection(ctx context.Context, collectionID UniqueID
|
||||||
}
|
}
|
||||||
hasCollection = has
|
hasCollection = has
|
||||||
return nil
|
return nil
|
||||||
}, retry.Attempts(500)); err != nil {
|
}, retry.Attempts(5)); err != nil {
|
||||||
log.Ctx(ctx2).Error("datacoord ServerHandler HasCollection finally failed", zap.Int64("collectionID", collectionID))
|
log.Ctx(ctx2).Error("datacoord ServerHandler HasCollection finally failed",
|
||||||
log.Panic("datacoord ServerHandler HasCollection finally failed")
|
zap.Int64("collectionID", collectionID),
|
||||||
|
zap.Error(err))
|
||||||
|
// A workaround for https://github.com/milvus-io/milvus/issues/26863. The collection may be considered as not
|
||||||
|
// dropped when any exception happened, but there are chances that finally the collection will be cleaned.
|
||||||
|
return true, nil
|
||||||
}
|
}
|
||||||
return hasCollection, nil
|
return hasCollection, nil
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue