mirror of
https://github.com/rclone/rclone.git
synced 2025-01-24 23:28:57 +01:00
backend/s3: use low-level-retries as the number of SDK retries
Amazon S3 is built to handle different kinds of workloads. In rare cases where S3 is not able to scale for whatever reason users will face status 500 errors. Main mechanism for handling these errors are retries. Amount of needed retries varies for each different use case. This change is making retries for s3 backend configurable by using --low-level-retries option.
This commit is contained in:
parent
ac9cb50fdb
commit
5470d34740
@ -850,7 +850,6 @@ In Ceph, this can be increased with the "rgw list buckets max chunk" option.
|
|||||||
Default: memoryPoolFlushTime,
|
Default: memoryPoolFlushTime,
|
||||||
Advanced: true,
|
Advanced: true,
|
||||||
Help: `How often internal memory buffer pools will be flushed.
|
Help: `How often internal memory buffer pools will be flushed.
|
||||||
|
|
||||||
Uploads which requires additional buffers (f.e multipart) will use memory pool for allocations.
|
Uploads which requires additional buffers (f.e multipart) will use memory pool for allocations.
|
||||||
This option controls how often unused buffers will be removed from the pool.`,
|
This option controls how often unused buffers will be removed from the pool.`,
|
||||||
}, {
|
}, {
|
||||||
@ -866,7 +865,6 @@ This option controls how often unused buffers will be removed from the pool.`,
|
|||||||
const (
|
const (
|
||||||
metaMtime = "Mtime" // the meta key to store mtime in - eg X-Amz-Meta-Mtime
|
metaMtime = "Mtime" // the meta key to store mtime in - eg X-Amz-Meta-Mtime
|
||||||
metaMD5Hash = "Md5chksum" // the meta key to store md5hash in
|
metaMD5Hash = "Md5chksum" // the meta key to store md5hash in
|
||||||
maxRetries = 10 // number of retries to make of operations
|
|
||||||
maxSizeForCopy = 5 * 1024 * 1024 * 1024 // The maximum size of object we can COPY
|
maxSizeForCopy = 5 * 1024 * 1024 * 1024 // The maximum size of object we can COPY
|
||||||
maxUploadParts = 10000 // maximum allowed number of parts in a multi-part upload
|
maxUploadParts = 10000 // maximum allowed number of parts in a multi-part upload
|
||||||
minChunkSize = fs.SizeSuffix(1024 * 1024 * 5)
|
minChunkSize = fs.SizeSuffix(1024 * 1024 * 5)
|
||||||
@ -1095,7 +1093,7 @@ func s3Connection(opt *Options) (*s3.S3, *session.Session, error) {
|
|||||||
opt.ForcePathStyle = false
|
opt.ForcePathStyle = false
|
||||||
}
|
}
|
||||||
awsConfig := aws.NewConfig().
|
awsConfig := aws.NewConfig().
|
||||||
WithMaxRetries(maxRetries).
|
WithMaxRetries(fs.Config.LowLevelRetries).
|
||||||
WithCredentials(cred).
|
WithCredentials(cred).
|
||||||
WithHTTPClient(fshttp.NewClient(fs.Config)).
|
WithHTTPClient(fshttp.NewClient(fs.Config)).
|
||||||
WithS3ForcePathStyle(opt.ForcePathStyle).
|
WithS3ForcePathStyle(opt.ForcePathStyle).
|
||||||
@ -1202,12 +1200,17 @@ func NewFs(name, root string, m configmap.Mapper) (fs.Fs, error) {
|
|||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pc := fs.NewPacer(pacer.NewS3(pacer.MinSleep(minSleep)))
|
||||||
|
// Set pacer retries to 0 because we are relying on SDK retry mechanism.
|
||||||
|
// Setting it to 1 because in context of pacer it means 1 attempt.
|
||||||
|
pc.SetRetries(1)
|
||||||
|
|
||||||
f := &Fs{
|
f := &Fs{
|
||||||
name: name,
|
name: name,
|
||||||
opt: *opt,
|
opt: *opt,
|
||||||
c: c,
|
c: c,
|
||||||
ses: ses,
|
ses: ses,
|
||||||
pacer: fs.NewPacer(pacer.NewS3(pacer.MinSleep(minSleep))),
|
pacer: pc,
|
||||||
cache: bucket.NewCache(),
|
cache: bucket.NewCache(),
|
||||||
srv: fshttp.NewClient(fs.Config),
|
srv: fshttp.NewClient(fs.Config),
|
||||||
pools: make(map[int64]*pool.Pool),
|
pools: make(map[int64]*pool.Pool),
|
||||||
|
Loading…
Reference in New Issue
Block a user