From c31d2c3fdc89748869375feecb28359f0d6e3910 Mon Sep 17 00:00:00 2001 From: Harshavardhana Date: Mon, 22 Feb 2021 10:04:32 -0800 Subject: [PATCH] fix: CrawlAndGetDataUsage close pipe() before using a new one (#11600) also additionally make sure errors during deserializer closes the reader with right error type such that Write() end actually see the final error, this avoids a waitGroup usage and waiting. --- cmd/data-usage-cache.go | 2 +- cmd/erasure.go | 5 +++-- cmd/storage-rest-client.go | 13 ++++--------- 3 files changed, 8 insertions(+), 12 deletions(-) diff --git a/cmd/data-usage-cache.go b/cmd/data-usage-cache.go index 739152974..664e95f80 100644 --- a/cmd/data-usage-cache.go +++ b/cmd/data-usage-cache.go @@ -485,7 +485,7 @@ type objectIO interface { // Only backend errors are returned as errors. // If the object is not found or unable to deserialize d is cleared and nil error is returned. func (d *dataUsageCache) load(ctx context.Context, store objectIO, name string) error { - r, err := store.GetObjectNInfo(ctx, dataUsageBucket, name, nil, http.Header{}, readLock, ObjectOptions{}) + r, err := store.GetObjectNInfo(ctx, dataUsageBucket, name, nil, http.Header{}, noLock, ObjectOptions{}) if err != nil { switch err.(type) { case ObjectNotFound: diff --git a/cmd/erasure.go b/cmd/erasure.go index 1a848a69a..24784316d 100644 --- a/cmd/erasure.go +++ b/cmd/erasure.go @@ -420,9 +420,10 @@ func (er erasureObjects) crawlAndGetDataUsage(ctx context.Context, buckets []Buc cache, err = disk.CrawlAndGetDataUsage(ctx, cache) cache.Info.BloomFilter = nil if err != nil { - logger.LogIf(ctx, err) - if cache.Info.LastUpdate.After(before) { + if !cache.Info.LastUpdate.IsZero() && cache.Info.LastUpdate.After(before) { logger.LogIf(ctx, cache.save(ctx, er, cacheName)) + } else { + logger.LogIf(ctx, err) } continue } diff --git a/cmd/storage-rest-client.go b/cmd/storage-rest-client.go index dcb1eca78..951153985 100644 --- a/cmd/storage-rest-client.go +++ b/cmd/storage-rest-client.go @@ -175,30 +175,25 @@ func (client *storageRESTClient) CrawlAndGetDataUsage(ctx context.Context, cache go func() { pw.CloseWithError(cache.serializeTo(pw)) }() - defer pr.Close() respBody, err := client.call(ctx, storageRESTMethodCrawlAndGetDataUsage, url.Values{}, pr, -1) defer http.DrainBody(respBody) if err != nil { + pr.Close() return cache, err } + pr.Close() - var wg sync.WaitGroup var newCache dataUsageCache - var decErr error pr, pw = io.Pipe() - wg.Add(1) go func() { - defer wg.Done() - decErr = newCache.deserialize(pr) - pr.CloseWithError(err) + pr.CloseWithError(newCache.deserialize(pr)) }() err = waitForHTTPStream(respBody, pw) pw.CloseWithError(err) if err != nil { return cache, err } - wg.Wait() - return newCache, decErr + return newCache, nil } func (client *storageRESTClient) GetDiskID() (string, error) {