mirror of
https://github.com/minio/minio.git
synced 2025-01-14 16:25:01 -05:00
use bigger partSize per part for tiering to MinIO (#19361)
Bonus: remove persistent md5sum calculation, turn-off sha256 as well. Instead we always enable crc32c which is enough for payload verification also support for trailing headers checksum.
This commit is contained in:
parent
289223b6de
commit
139a606f0a
@ -18,8 +18,11 @@
|
|||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"context"
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"io"
|
||||||
|
"math"
|
||||||
"net/url"
|
"net/url"
|
||||||
"strings"
|
"strings"
|
||||||
"time"
|
"time"
|
||||||
@ -35,6 +38,60 @@ type warmBackendMinIO struct {
|
|||||||
|
|
||||||
var _ WarmBackend = (*warmBackendMinIO)(nil)
|
var _ WarmBackend = (*warmBackendMinIO)(nil)
|
||||||
|
|
||||||
|
const (
|
||||||
|
maxMultipartPutObjectSize = 1024 * 1024 * 1024 * 1024 * 5
|
||||||
|
maxPartsCount = 10000
|
||||||
|
maxPartSize = 1024 * 1024 * 1024 * 5
|
||||||
|
minPartSize = 1024 * 1024 * 64 // chosen by us to be optimal for HDDs
|
||||||
|
)
|
||||||
|
|
||||||
|
// optimalPartInfo - calculate the optimal part info for a given
|
||||||
|
// object size.
|
||||||
|
//
|
||||||
|
// NOTE: Assumption here is that for any object to be uploaded to any S3 compatible
|
||||||
|
// object storage it will have the following parameters as constants.
|
||||||
|
//
|
||||||
|
// maxPartsCount - 10000
|
||||||
|
// maxMultipartPutObjectSize - 5TiB
|
||||||
|
func optimalPartSize(objectSize int64) (partSize int64, err error) {
|
||||||
|
// object size is '-1' set it to 5TiB.
|
||||||
|
if objectSize == -1 {
|
||||||
|
objectSize = maxMultipartPutObjectSize
|
||||||
|
}
|
||||||
|
|
||||||
|
// object size is larger than supported maximum.
|
||||||
|
if objectSize > maxMultipartPutObjectSize {
|
||||||
|
err = errors.New("entity too large")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
configuredPartSize := minPartSize
|
||||||
|
// Use floats for part size for all calculations to avoid
|
||||||
|
// overflows during float64 to int64 conversions.
|
||||||
|
partSizeFlt := float64(objectSize / maxPartsCount)
|
||||||
|
partSizeFlt = math.Ceil(partSizeFlt/float64(configuredPartSize)) * float64(configuredPartSize)
|
||||||
|
|
||||||
|
// Part size.
|
||||||
|
partSize = int64(partSizeFlt)
|
||||||
|
if partSize == 0 {
|
||||||
|
return minPartSize, nil
|
||||||
|
}
|
||||||
|
return partSize, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *warmBackendMinIO) Put(ctx context.Context, object string, r io.Reader, length int64) (remoteVersionID, error) {
|
||||||
|
partSize, err := optimalPartSize(length)
|
||||||
|
if err != nil {
|
||||||
|
return remoteVersionID(""), err
|
||||||
|
}
|
||||||
|
res, err := m.client.PutObject(ctx, m.Bucket, m.getDest(object), r, length, minio.PutObjectOptions{
|
||||||
|
StorageClass: m.StorageClass,
|
||||||
|
PartSize: uint64(partSize),
|
||||||
|
DisableContentSha256: true,
|
||||||
|
})
|
||||||
|
return remoteVersionID(res.VersionID), m.ToObjectError(err, object)
|
||||||
|
}
|
||||||
|
|
||||||
func newWarmBackendMinIO(conf madmin.TierMinIO, tier string) (*warmBackendMinIO, error) {
|
func newWarmBackendMinIO(conf madmin.TierMinIO, tier string) (*warmBackendMinIO, error) {
|
||||||
// Validation of credentials
|
// Validation of credentials
|
||||||
if conf.AccessKey == "" || conf.SecretKey == "" {
|
if conf.AccessKey == "" || conf.SecretKey == "" {
|
||||||
@ -59,6 +116,7 @@ func newWarmBackendMinIO(conf madmin.TierMinIO, tier string) (*warmBackendMinIO,
|
|||||||
Creds: creds,
|
Creds: creds,
|
||||||
Secure: u.Scheme == "https",
|
Secure: u.Scheme == "https",
|
||||||
Transport: getRemoteTierTargetInstanceTransport,
|
Transport: getRemoteTierTargetInstanceTransport,
|
||||||
|
TrailingHeaders: true,
|
||||||
}
|
}
|
||||||
client, err := minio.New(u.Host, opts)
|
client, err := minio.New(u.Host, opts)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
Loading…
Reference in New Issue
Block a user