s3: Make sure to return connection token
This commit is contained in:
parent
64165ea4c8
commit
7a0303f7ae
1 changed files with 12 additions and 0 deletions
|
@ -155,11 +155,16 @@ func (be *s3) Load(h restic.Handle, length int, offset int64) (io.ReadCloser, er
|
||||||
|
|
||||||
objName := be.s3path(h)
|
objName := be.s3path(h)
|
||||||
|
|
||||||
|
// get token for connection
|
||||||
<-be.connChan
|
<-be.connChan
|
||||||
|
|
||||||
obj, err := be.client.GetObject(be.bucketname, objName)
|
obj, err := be.client.GetObject(be.bucketname, objName)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
debug.Log(" err %v", err)
|
debug.Log(" err %v", err)
|
||||||
|
|
||||||
|
// return token
|
||||||
|
be.connChan <- struct{}{}
|
||||||
|
|
||||||
return nil, errors.Wrap(err, "client.GetObject")
|
return nil, errors.Wrap(err, "client.GetObject")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -170,12 +175,18 @@ func (be *s3) Load(h restic.Handle, length int, offset int64) (io.ReadCloser, er
|
||||||
_, err = obj.Seek(offset, 0)
|
_, err = obj.Seek(offset, 0)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
_ = obj.Close()
|
_ = obj.Close()
|
||||||
|
|
||||||
|
// return token
|
||||||
|
be.connChan <- struct{}{}
|
||||||
|
|
||||||
return nil, errors.Wrap(err, "obj.Seek")
|
return nil, errors.Wrap(err, "obj.Seek")
|
||||||
}
|
}
|
||||||
|
|
||||||
rd := wrapReader{
|
rd := wrapReader{
|
||||||
ReadCloser: obj,
|
ReadCloser: obj,
|
||||||
f: func() {
|
f: func() {
|
||||||
|
debug.Log("Close()")
|
||||||
|
// return token
|
||||||
be.connChan <- struct{}{}
|
be.connChan <- struct{}{}
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
@ -183,6 +194,7 @@ func (be *s3) Load(h restic.Handle, length int, offset int64) (io.ReadCloser, er
|
||||||
}
|
}
|
||||||
|
|
||||||
defer func() {
|
defer func() {
|
||||||
|
// return token
|
||||||
be.connChan <- struct{}{}
|
be.connChan <- struct{}{}
|
||||||
}()
|
}()
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue