|
@ -1,6 +1,7 @@ |
|
|
package S3Sink |
|
|
package S3Sink |
|
|
|
|
|
|
|
|
import ( |
|
|
import ( |
|
|
|
|
|
"bytes" |
|
|
"context" |
|
|
"context" |
|
|
"fmt" |
|
|
"fmt" |
|
|
"strings" |
|
|
"strings" |
|
@ -121,6 +122,7 @@ func (s3sink *S3Sink) CreateEntry(key string, entry *filer_pb.Entry, signatures |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
totalSize := filer.FileSize(entry) |
|
|
totalSize := filer.FileSize(entry) |
|
|
|
|
|
|
|
|
chunkViews := filer.ViewFromChunks(s3sink.filerSource.LookupFileId, entry.Chunks, 0, int64(totalSize)) |
|
|
chunkViews := filer.ViewFromChunks(s3sink.filerSource.LookupFileId, entry.Chunks, 0, int64(totalSize)) |
|
|
|
|
|
|
|
|
parts := make([]*s3.CompletedPart, len(chunkViews)) |
|
|
parts := make([]*s3.CompletedPart, len(chunkViews)) |
|
@ -141,6 +143,17 @@ func (s3sink *S3Sink) CreateEntry(key string, entry *filer_pb.Entry, signatures |
|
|
} |
|
|
} |
|
|
wg.Wait() |
|
|
wg.Wait() |
|
|
|
|
|
|
|
|
|
|
|
// for small files
|
|
|
|
|
|
if len(entry.Content) > 0 { |
|
|
|
|
|
parts = make([]*s3.CompletedPart, 1) |
|
|
|
|
|
if part, uploadErr := s3sink.doUploadPart(key, uploadId, 1, bytes.NewReader(entry.Content)); uploadErr != nil { |
|
|
|
|
|
err = uploadErr |
|
|
|
|
|
glog.Errorf("uploadPart: %v", uploadErr) |
|
|
|
|
|
} else { |
|
|
|
|
|
parts[0] = part |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
if err != nil { |
|
|
if err != nil { |
|
|
s3sink.abortMultipartUpload(key, uploadId) |
|
|
s3sink.abortMultipartUpload(key, uploadId) |
|
|
return fmt.Errorf("uploadPart: %v", err) |
|
|
return fmt.Errorf("uploadPart: %v", err) |
|
|