mirror of https://github.com/apache/jclouds.git
JCLOUDS-1369: improving slicing with many parts
Previously with GCS and its maximum 32 parts, the slicing algorithm would sliced 3.2 GB blobs into (31) 32 MB parts and (1) 2.3 GB part. With this algorithm it creates (31) 100 MB parts and (1) smaller part.
This commit is contained in:
parent
d05be89614
commit
8cd68a3503
|
@ -103,14 +103,10 @@ public final class MultipartUploadSlicingAlgorithm {
|
||||||
unitPartSize = maximumPartSize;
|
unitPartSize = maximumPartSize;
|
||||||
parts = (int)(length / unitPartSize);
|
parts = (int)(length / unitPartSize);
|
||||||
}
|
}
|
||||||
if (parts > maximumNumberOfParts) { // if splits in too many parts or
|
if (parts > maximumNumberOfParts) {
|
||||||
// cannot be split
|
partSize = length / maximumNumberOfParts;
|
||||||
unitPartSize = minimumPartSize; // take the minimum part size
|
unitPartSize = partSize;
|
||||||
parts = (int)(length / unitPartSize);
|
parts = maximumNumberOfParts;
|
||||||
}
|
|
||||||
if (parts > maximumNumberOfParts) { // if still splits in too many parts
|
|
||||||
parts = maximumNumberOfParts - 1; // limit them. do not care about not
|
|
||||||
// covering
|
|
||||||
}
|
}
|
||||||
long remainder = length % unitPartSize;
|
long remainder = length % unitPartSize;
|
||||||
if (remainder == 0 && parts > 0) {
|
if (remainder == 0 && parts > 0) {
|
||||||
|
|
Loading…
Reference in New Issue