From 89bb9f17d73882127203e07c63d288d77525f1c6 Mon Sep 17 00:00:00 2001 From: Harshavardhana Date: Thu, 27 May 2021 13:38:04 -0700 Subject: [PATCH] fix: when parityDrives hits > len(storageDisks)/2, keep maxParity (#12387) Additionally move out `x-minio-internal-erasure-upgraded` from HTTP headers list, as its an internal header, rename elsewhere accordingly. --- cmd/erasure-metadata.go | 3 +++ cmd/erasure-multipart.go | 7 ++++--- cmd/erasure-object.go | 8 +++++--- cmd/http/headers.go | 3 --- 4 files changed, 12 insertions(+), 9 deletions(-) diff --git a/cmd/erasure-metadata.go b/cmd/erasure-metadata.go index 099da0e73..bc6fd90c7 100644 --- a/cmd/erasure-metadata.go +++ b/cmd/erasure-metadata.go @@ -32,6 +32,9 @@ import ( "github.com/minio/minio/pkg/sync/errgroup" ) +// Object was stored with additional erasure codes due to degraded system at upload time +const minIOErasureUpgraded = "x-minio-internal-erasure-upgraded" + const erasureAlgorithm = "rs-vandermonde" // byObjectPartNumber is a collection satisfying sort.Interface. diff --git a/cmd/erasure-multipart.go b/cmd/erasure-multipart.go index 6015080dd..b4088d9ef 100644 --- a/cmd/erasure-multipart.go +++ b/cmd/erasure-multipart.go @@ -289,9 +289,10 @@ func (er erasureObjects) newMultipartUpload(ctx context.Context, bucket string, parityDrives = er.defaultParityCount } - ecOrg := parityDrives + parityOrig := parityDrives for _, disk := range onlineDisks { if parityDrives >= len(onlineDisks)/2 { + parityDrives = len(onlineDisks) / 2 break } if disk == nil { @@ -303,8 +304,8 @@ func (er erasureObjects) newMultipartUpload(ctx context.Context, bucket string, parityDrives++ } } - if ecOrg != parityDrives { - opts.UserDefined[xhttp.MinIOErasureUpgraded] = fmt.Sprintf("%d->%d", ecOrg, parityDrives) + if parityOrig != parityDrives { + opts.UserDefined[minIOErasureUpgraded] = strconv.Itoa(parityOrig) + "->" + strconv.Itoa(parityDrives) } dataDrives := len(onlineDisks) - parityDrives diff --git a/cmd/erasure-object.go b/cmd/erasure-object.go index cb4ed73b7..edf65cd8e 100644 --- a/cmd/erasure-object.go +++ b/cmd/erasure-object.go @@ -25,6 +25,7 @@ import ( "io" "net/http" "path" + "strconv" "strings" "sync" @@ -601,9 +602,10 @@ func (er erasureObjects) putObject(ctx context.Context, bucket string, object st } // If we have offline disks upgrade the number of erasure codes for this object. - ecOrg := parityDrives + parityOrig := parityDrives for _, disk := range storageDisks { if parityDrives >= len(storageDisks)/2 { + parityDrives = len(storageDisks) / 2 break } if disk == nil { @@ -614,8 +616,8 @@ func (er erasureObjects) putObject(ctx context.Context, bucket string, object st parityDrives++ } } - if ecOrg != parityDrives { - opts.UserDefined[xhttp.MinIOErasureUpgraded] = fmt.Sprintf("%d->%d", ecOrg, parityDrives) + if parityOrig != parityDrives { + opts.UserDefined[minIOErasureUpgraded] = strconv.Itoa(parityOrig) + "->" + strconv.Itoa(parityDrives) } } dataDrives := len(storageDisks) - parityDrives diff --git a/cmd/http/headers.go b/cmd/http/headers.go index bd053027a..14f0a5f6e 100644 --- a/cmd/http/headers.go +++ b/cmd/http/headers.go @@ -156,9 +156,6 @@ const ( // Reports number of drives currently healing MinIOHealingDrives = "x-minio-healing-drives" - // Object was stored with additional erasure codes due to degraded system at upload time - MinIOErasureUpgraded = "x-minio-internal-erasure-upgraded" - // Header indicates if the delete marker should be preserved by client MinIOSourceDeleteMarker = "x-minio-source-deletemarker"