S3: do not set storage class for metadata when using archive storage

This commit is contained in:
Vladislav Belous 2023-12-05 00:20:27 +02:00 committed by Michael Eischer
parent 62111f4379
commit 8ca58b487c
2 changed files with 21 additions and 2 deletions

View file

@ -0,0 +1,9 @@
Bugfix: Ignoring the s3.storage-class option for metadata when archive tier is specified
Restic now will save snapshot metadata to non-archive storage tier whatsoever,
this will help avoid issues when data is being saved to archive storage class.
It is not providing any support for cold storages in restic,
only saving users from making backups unusable.
https://github.com/restic/restic/issues/4583
https://github.com/restic/restic/issues/3202

View file

@ -325,12 +325,22 @@ func (be *Backend) Path() string {
return be.cfg.Prefix return be.cfg.Prefix
} }
// useStorageClass returns whether file should be saved in the provided Storage Class
func (be *Backend) useStorageClass(h backend.Handle) bool {
var notArchiveClass bool = be.cfg.StorageClass != "GLACIER" && be.cfg.StorageClass != "DEEP_ARCHIVE"
isDataFile := h.Type == backend.PackFile && !h.IsMetadata
return isDataFile || notArchiveClass
}
// Save stores data in the backend at the handle. // Save stores data in the backend at the handle.
func (be *Backend) Save(ctx context.Context, h backend.Handle, rd backend.RewindReader) error { func (be *Backend) Save(ctx context.Context, h backend.Handle, rd backend.RewindReader) error {
objName := be.Filename(h) objName := be.Filename(h)
opts := minio.PutObjectOptions{StorageClass: be.cfg.StorageClass} opts := minio.PutObjectOptions{ContentType: "application/octet-stream"}
opts.ContentType = "application/octet-stream"
if be.useStorageClass(h) {
opts.StorageClass = be.cfg.StorageClass
}
// the only option with the high-level api is to let the library handle the checksum computation // the only option with the high-level api is to let the library handle the checksum computation
opts.SendContentMd5 = true opts.SendContentMd5 = true
// only use multipart uploads for very large files // only use multipart uploads for very large files