|
|
@ -427,6 +427,7 @@ type MultiUploadOptions struct { |
|
|
|
} |
|
|
|
|
|
|
|
// MultiUpload 为高级upload接口,并发分块上传
|
|
|
|
// 注意该接口目前只供参考
|
|
|
|
//
|
|
|
|
// 需要指定分块大小 partSize >= 1 ,单位为MB
|
|
|
|
// 同时请确认分块数量不超过10000
|
|
|
@ -463,6 +464,9 @@ func (s *ObjectService) MultiUpload(ctx context.Context, name string, r io.Reade |
|
|
|
if err != io.EOF { |
|
|
|
return nil, nil, err |
|
|
|
} |
|
|
|
// If read fail also need to create i index respon in chan,
|
|
|
|
// in case below out of index to panic.
|
|
|
|
chs[i] = make(chan *Response) |
|
|
|
PartNumber = i |
|
|
|
break |
|
|
|
} |
|
|
@ -473,6 +477,10 @@ func (s *ObjectService) MultiUpload(ctx context.Context, name string, r io.Reade |
|
|
|
for i := 1; i < PartNumber; i++ { |
|
|
|
resp := <-chs[i] |
|
|
|
// Notice one part fail can not get the etag according.
|
|
|
|
if resp == nil { |
|
|
|
// Some part already fail, can not to get the header inside.
|
|
|
|
return nil, nil, fmt.Errorf("UploadID %s, part %d failed to get resp content.", uploadID, i) |
|
|
|
} |
|
|
|
etag := resp.Header.Get("ETag") |
|
|
|
optcom.Parts = append(optcom.Parts, Object{ |
|
|
|
PartNumber: i, ETag: etag}, |
|
|
|