From e413f05397ee19fb0797c55cae46afb69c7f340d Mon Sep 17 00:00:00 2001 From: Klaus Post Date: Wed, 18 Nov 2020 10:28:22 -0800 Subject: [PATCH] Save listing error async (#10922) Since the RPC call may have to time out save an error state async to not hold up the listing returning. Fixes #10919 --- cmd/metacache-server-sets.go | 20 +++++++++++++------- cmd/metacache-set.go | 16 +++++++++------- 2 files changed, 22 insertions(+), 14 deletions(-) diff --git a/cmd/metacache-server-sets.go b/cmd/metacache-server-sets.go index a779865af..ee75c71af 100644 --- a/cmd/metacache-server-sets.go +++ b/cmd/metacache-server-sets.go @@ -22,6 +22,7 @@ import ( "io" "path" "sync" + "time" "github.com/minio/minio/cmd/logger" ) @@ -103,14 +104,18 @@ func (z *erasureServerSets) listPath(ctx context.Context, o listPathOptions) (en // Local cache = localMetacacheMgr.findCache(ctx, o) } else { + ctx, cancel := context.WithTimeout(ctx, 5*time.Second) + defer cancel() c, err := rpc.GetMetacacheListing(ctx, o) if err != nil { - if errors.Is(err, context.Canceled) || errors.Is(err, context.DeadlineExceeded) { + if errors.Is(err, context.Canceled) { // Context is canceled, return at once. // request canceled, no entries to return return entries, io.EOF } - logger.LogIf(ctx, err) + if !errors.Is(err, context.DeadlineExceeded) { + logger.LogIf(ctx, err) + } o.Transient = true cache = localMetacacheMgr.findCache(ctx, o) } else { @@ -176,11 +181,12 @@ func (z *erasureServerSets) listPath(ctx context.Context, o listPathOptions) (en if isAllNotFound(errs) { // All sets returned not found. - // Update master cache with that information. - cache.status = scanStateSuccess - cache.fileNotFound = true - _, err := o.updateMetacacheListing(cache, globalNotificationSys.restClientFromHash(o.Bucket)) - logger.LogIf(ctx, err) + go func() { + // Update master cache with that information. + cache.status = scanStateSuccess + cache.fileNotFound = true + o.updateMetacacheListing(cache, globalNotificationSys.restClientFromHash(o.Bucket)) + }() // cache returned not found, entries truncated. return entries, io.EOF } diff --git a/cmd/metacache-set.go b/cmd/metacache-set.go index 525e797d9..9e8948011 100644 --- a/cmd/metacache-set.go +++ b/cmd/metacache-set.go @@ -560,13 +560,15 @@ func (er *erasureObjects) listPath(ctx context.Context, o listPathOptions) (entr console.Println("listPath returning:", entries.len(), "err:", err) } if err != nil && err != io.EOF { - metaMu.Lock() - if meta.status != scanStateError { - meta.error = err.Error() - meta.status = scanStateError - } - meta, _ = o.updateMetacacheListing(meta, rpc) - metaMu.Unlock() + go func(err string) { + metaMu.Lock() + if meta.status != scanStateError { + meta.error = err + meta.status = scanStateError + } + meta, _ = o.updateMetacacheListing(meta, rpc) + metaMu.Unlock() + }(err.Error()) cancel() } }()