diff --git a/cmd/erasure-bucket.go b/cmd/erasure-bucket.go index 763e2291e..058eeeb58 100644 --- a/cmd/erasure-bucket.go +++ b/cmd/erasure-bucket.go @@ -39,8 +39,10 @@ func (er erasureObjects) MakeBucketWithLocation(ctx context.Context, bucket stri defer NSUpdated(bucket, slashSeparator) // Verify if bucket is valid. - if err := s3utils.CheckValidBucketNameStrict(bucket); err != nil { - return BucketNameInvalid{Bucket: bucket} + if !isMinioMetaBucketName(bucket) { + if err := s3utils.CheckValidBucketNameStrict(bucket); err != nil { + return BucketNameInvalid{Bucket: bucket} + } } storageDisks := er.getDisks() diff --git a/cmd/erasure-server-pool-decom.go b/cmd/erasure-server-pool-decom.go index bd44ebe79..06c594015 100644 --- a/cmd/erasure-server-pool-decom.go +++ b/cmd/erasure-server-pool-decom.go @@ -962,8 +962,11 @@ func (z *erasureServerPools) StartDecommission(ctx context.Context, idx int) (er pathJoin(minioMetaBucket, minioConfigPrefix), pathJoin(minioMetaBucket, bucketMetaPrefix), } { + var bucketExists BucketExists if err = z.MakeBucketWithLocation(ctx, metaBucket, BucketOptions{}); err != nil { - return err + if !errors.As(err, &bucketExists) { + return err + } } }