Add a rotating buffer functionality to the s3 driver
This commit is contained in:
parent
f0e0a080e9
commit
c05e4682f8
1 changed files with 29 additions and 7 deletions
|
@ -284,6 +284,7 @@ func (d *Driver) WriteStream(path string, offset int64, reader io.Reader) (total
|
||||||
|
|
||||||
partNumber := 1
|
partNumber := 1
|
||||||
bytesRead := 0
|
bytesRead := 0
|
||||||
|
var putErrChan chan error
|
||||||
parts := []s3.Part{}
|
parts := []s3.Part{}
|
||||||
var part s3.Part
|
var part s3.Part
|
||||||
|
|
||||||
|
@ -303,6 +304,12 @@ func (d *Driver) WriteStream(path string, offset int64, reader io.Reader) (total
|
||||||
// multipart upload, which will eventually be cleaned up, but we will lose all of the progress
|
// multipart upload, which will eventually be cleaned up, but we will lose all of the progress
|
||||||
// made prior to the machine crashing.
|
// made prior to the machine crashing.
|
||||||
defer func() {
|
defer func() {
|
||||||
|
if putErrChan != nil {
|
||||||
|
if putErr := <-putErrChan; putErr != nil {
|
||||||
|
err = putErr
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if len(parts) > 0 {
|
if len(parts) > 0 {
|
||||||
if multi == nil {
|
if multi == nil {
|
||||||
// Parts should be empty if the multi is not initialized
|
// Parts should be empty if the multi is not initialized
|
||||||
|
@ -356,16 +363,31 @@ func (d *Driver) WriteStream(path string, offset int64, reader io.Reader) (total
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if bytesRead > 0 {
|
if putErrChan == nil {
|
||||||
part, err = multi.PutPart(int(partNumber), bytes.NewReader(buf[0:int64(bytesRead)+from]))
|
putErrChan = make(chan error)
|
||||||
if err != nil {
|
} else {
|
||||||
return err
|
if putErr := <-putErrChan; putErr != nil {
|
||||||
|
putErrChan = nil
|
||||||
|
return putErr
|
||||||
}
|
}
|
||||||
|
|
||||||
parts = append(parts, part)
|
|
||||||
partNumber++
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
go func(bytesRead int, from int64, buf []byte) {
|
||||||
|
// parts and partNumber are safe, because this function is the only one modifying them and we
|
||||||
|
// force it to be executed serially.
|
||||||
|
if bytesRead > 0 {
|
||||||
|
part, putErr := multi.PutPart(int(partNumber), bytes.NewReader(buf[0:int64(bytesRead)+from]))
|
||||||
|
if putErr != nil {
|
||||||
|
putErrChan <- putErr
|
||||||
|
}
|
||||||
|
|
||||||
|
parts = append(parts, part)
|
||||||
|
partNumber++
|
||||||
|
}
|
||||||
|
putErrChan <- nil
|
||||||
|
}(bytesRead, from, buf)
|
||||||
|
|
||||||
|
buf = make([]byte, d.ChunkSize)
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue