Cache size of last ReadAt on S3 for performance
Each obj.Stat() call adds another request to the S3 endpoint for some commands a lot of ReadAt calls are made for the same object in S3. This patch essentially cuts the number of calls to S3 in this case in half. Speeding up the progress and lowering costs to S3.
This commit is contained in:
parent
bf30b2831b
commit
b523eef294
1 changed files with 21 additions and 11 deletions
|
@ -24,6 +24,8 @@ type s3 struct {
|
||||||
connChan chan struct{}
|
connChan chan struct{}
|
||||||
bucketname string
|
bucketname string
|
||||||
prefix string
|
prefix string
|
||||||
|
cacheObjName string
|
||||||
|
cacheSize int64
|
||||||
}
|
}
|
||||||
|
|
||||||
// Open opens the S3 backend at bucket and region. The bucket is created if it
|
// Open opens the S3 backend at bucket and region. The bucket is created if it
|
||||||
|
@ -139,6 +141,7 @@ func (be *s3) Load(h restic.Handle, length int, offset int64) (io.ReadCloser, er
|
||||||
}
|
}
|
||||||
|
|
||||||
var obj *minio.Object
|
var obj *minio.Object
|
||||||
|
var size int64
|
||||||
|
|
||||||
objName := be.s3path(h)
|
objName := be.s3path(h)
|
||||||
|
|
||||||
|
@ -186,20 +189,27 @@ func (be *s3) Load(h restic.Handle, length int, offset int64) (io.ReadCloser, er
|
||||||
}()
|
}()
|
||||||
|
|
||||||
// otherwise use a buffer with ReadAt
|
// otherwise use a buffer with ReadAt
|
||||||
|
if be.cacheObjName == objName {
|
||||||
|
size = be.cacheSize
|
||||||
|
} else {
|
||||||
info, err := obj.Stat()
|
info, err := obj.Stat()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
_ = obj.Close()
|
_ = obj.Close()
|
||||||
return nil, errors.Wrap(err, "obj.Stat")
|
return nil, errors.Wrap(err, "obj.Stat")
|
||||||
}
|
}
|
||||||
|
size = info.Size
|
||||||
|
be.cacheObjName = objName
|
||||||
|
be.cacheSize = size
|
||||||
|
}
|
||||||
|
|
||||||
if offset > info.Size {
|
if offset > size {
|
||||||
_ = obj.Close()
|
_ = obj.Close()
|
||||||
return nil, errors.New("offset larger than file size")
|
return nil, errors.New("offset larger than file size")
|
||||||
}
|
}
|
||||||
|
|
||||||
l := int64(length)
|
l := int64(length)
|
||||||
if offset+l > info.Size {
|
if offset+l > size {
|
||||||
l = info.Size - offset
|
l = size - offset
|
||||||
}
|
}
|
||||||
|
|
||||||
buf := make([]byte, l)
|
buf := make([]byte, l)
|
||||||
|
|
Loading…
Reference in a new issue