当前位置: 首页>>代码示例>>Java>>正文


Java PartETag类代码示例

本文整理汇总了Java中com.amazonaws.services.s3.model.PartETag的典型用法代码示例。如果您正苦于以下问题:Java PartETag类的具体用法?Java PartETag怎么用?Java PartETag使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。


PartETag类属于com.amazonaws.services.s3.model包,在下文中一共展示了PartETag类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: uploadMultipart

import com.amazonaws.services.s3.model.PartETag; //导入依赖的package包/类
private void uploadMultipart(byte[] bytes, int off, int len, boolean lastPart) throws IOException {
    try (ByteArrayInputStream is = new ByteArrayInputStream(bytes, off, len)) {
        int retry = 0;
        while (retry <= getNumberOfRetries()) {
            try {
                PartETag partETag = doUploadMultipart(getBlobStore(), getBucketName(), getBlobName(), multipartId, is, len, lastPart);
                multiparts.add(partETag);
                multipartChunks++;
                return;
            } catch (AmazonClientException e) {
                if (getBlobStore().shouldRetry(e) && retry < getNumberOfRetries()) {
                    is.reset();
                    retry++;
                } else {
                    abortMultipart();
                    throw e;
                }
            }
        }
    }
}
 
开发者ID:justor,项目名称:elasticsearch_my,代码行数:22,代码来源:DefaultS3OutputStream.java

示例2: uploadPartAsync

import com.amazonaws.services.s3.model.PartETag; //导入依赖的package包/类
public void uploadPartAsync(ByteArrayInputStream inputStream,
    int partSize) {
  final int currentPartNumber = partETagsFutures.size() + 1;
  final UploadPartRequest request =
      new UploadPartRequest().withBucketName(bucket).withKey(key)
          .withUploadId(uploadId).withInputStream(inputStream)
          .withPartNumber(currentPartNumber).withPartSize(partSize);
  request.setGeneralProgressListener(progressListener);
  ListenableFuture<PartETag> partETagFuture =
      executorService.submit(new Callable<PartETag>() {
        @Override
        public PartETag call() throws Exception {
          if (LOG.isDebugEnabled()) {
            LOG.debug("Uploading part {} for id '{}'", currentPartNumber,
                uploadId);
          }
          return client.uploadPart(request).getPartETag();
        }
      });
  partETagsFutures.add(partETagFuture);
}
 
开发者ID:naver,项目名称:hadoop,代码行数:22,代码来源:S3AFastOutputStream.java

示例3: waitForAllPartUploads

import com.amazonaws.services.s3.model.PartETag; //导入依赖的package包/类
public List<PartETag> waitForAllPartUploads() throws IOException {
  try {
    return Futures.allAsList(partETagsFutures).get();
  } catch (InterruptedException ie) {
    LOG.warn("Interrupted partUpload:" + ie, ie);
    Thread.currentThread().interrupt();
  } catch (ExecutionException ee) {
    //there is no way of recovering so abort
    //cancel all partUploads
    for (ListenableFuture<PartETag> future : partETagsFutures) {
      future.cancel(true);
    }
    //abort multipartupload
    this.abort();
    throw new IOException("Part upload failed in multi-part upload with " +
        "id '" +uploadId + "':" + ee, ee);
  }
  //should not happen?
  return null;
}
 
开发者ID:naver,项目名称:hadoop,代码行数:21,代码来源:S3AFastOutputStream.java

示例4: collectPartETags

import com.amazonaws.services.s3.model.PartETag; //导入依赖的package包/类
/**
 * Collects the Part ETags for initiating the complete multi-part upload
 * request. This is blocking as it waits until all the upload part threads
 * complete.
 */
private List<PartETag> collectPartETags() {

    final List<PartETag> partETags = new ArrayList<PartETag>();
    partETags.addAll(eTagsBeforeResume);
    for (Future<PartETag> future : futures) {
        try {
            partETags.add(future.get());
        } catch (Exception e) {
            throw new SdkClientException(
                    "Unable to complete multi-part upload. Individual part upload failed : "
                            + e.getCause().getMessage(), e.getCause());
        }
    }
    return partETags;
}
 
开发者ID:IBM,项目名称:ibm-cos-sdk-java,代码行数:21,代码来源:CompleteMultipartUpload.java

示例5: uploadPartsInParallel

import com.amazonaws.services.s3.model.PartETag; //导入依赖的package包/类
/**
 * Submits a callable for each part to upload to our thread pool and records its corresponding Future.
 */
private void uploadPartsInParallel(UploadPartRequestFactory requestFactory,
        String uploadId) {

    Map<Integer,PartSummary> partNumbers = identifyExistingPartsForResume(uploadId);

    while (requestFactory.hasMoreRequests()) {
        if (threadPool.isShutdown()) throw new CancellationException("TransferManager has been shutdown");
        UploadPartRequest request = requestFactory.getNextUploadPartRequest();
        if (partNumbers.containsKey(request.getPartNumber())) {
            PartSummary summary = partNumbers.get(request.getPartNumber());
            eTagsToSkip.add(new PartETag(request.getPartNumber(), summary
                    .getETag()));
            transferProgress.updateProgress(summary.getSize());
            continue;
        }
        futures.add(threadPool.submit(new UploadPartCallable(s3, request)));
    }
}
 
开发者ID:IBM,项目名称:ibm-cos-sdk-java,代码行数:22,代码来源:UploadCallable.java

示例6: convertToXmlByteArray

import com.amazonaws.services.s3.model.PartETag; //导入依赖的package包/类
/**
 * Converts the specified list of PartETags to an XML fragment that can be
 * sent to the CompleteMultipartUpload operation of Amazon S3.
 *
 * @param partETags
 *            The list of part ETags containing the data to include in the
 *            new XML fragment.
 *
 * @return A byte array containing the data
 */
public static byte[] convertToXmlByteArray(List<PartETag> partETags) {
    XmlWriter xml = new XmlWriter();
    xml.start("CompleteMultipartUpload");
    if (partETags != null) {
        List<PartETag> sortedPartETags = new ArrayList<PartETag>(partETags);
        Collections.sort(sortedPartETags, new Comparator<PartETag>() {
            public int compare(PartETag tag1, PartETag tag2) {
                if (tag1.getPartNumber() < tag2.getPartNumber()) return -1;
                if (tag1.getPartNumber() > tag2.getPartNumber()) return 1;
                return 0;
            }
        });

        for (PartETag partEtag : sortedPartETags) {
            xml.start("Part");
            xml.start("PartNumber").value(Integer.toString(partEtag.getPartNumber())).end();
            xml.start("ETag").value(partEtag.getETag()).end();
            xml.end();
        }
    }
    xml.end();

    return xml.getBytes();
}
 
开发者ID:IBM,项目名称:ibm-cos-sdk-java,代码行数:35,代码来源:RequestXmlFactory.java

示例7: waitForAllPartUploads

import com.amazonaws.services.s3.model.PartETag; //导入依赖的package包/类
/**
 * Block awaiting all outstanding uploads to complete.
 *
 * @return list of results
 * @throws IOException IO Problems
 */
private List<PartETag> waitForAllPartUploads() throws IOException {
  LOG.debug("Waiting for {} uploads to complete", partETagsFutures.size());
  try {
    return Futures.allAsList(partETagsFutures).get();
  } catch (InterruptedException ie) {
    LOG.warn("Interrupted partUpload", ie);
    Thread.currentThread().interrupt();
    return null;
  } catch (ExecutionException ee) {
    // there is no way of recovering so abort
    // cancel all partUploads
    LOG.debug("While waiting for upload completion", ee);
    LOG.debug("Cancelling futures");
    for (ListenableFuture<PartETag> future : partETagsFutures) {
      future.cancel(true);
    }
    // abort multipartupload
    abort();
    throw extractException("Multi-part upload with id '" + uploadId + "' to " + key, key, ee);
  }
}
 
开发者ID:SparkTC,项目名称:stocator,代码行数:28,代码来源:COSBlockOutputStream.java

示例8: complete

import com.amazonaws.services.s3.model.PartETag; //导入依赖的package包/类
/**
 * This completes a multipart upload. Sometimes it fails; here retries are
 * handled to avoid losing all data on a transient failure.
 *
 * @param partETags list of partial uploads
 * @throws IOException on any problem
 */
private CompleteMultipartUploadResult complete(List<PartETag> partETags) throws IOException {
  int retryCount = 0;
  AmazonClientException lastException;
  String operation = String.format("Completing multi-part upload for key '%s',"
      + " id '%s' with %s partitions ",
      key, uploadId, partETags.size());
  do {
    try {
      LOG.debug(operation);
      return writeOperationHelper.completeMultipartUpload(uploadId, partETags);
    } catch (AmazonClientException e) {
      lastException = e;
    }
  } while (shouldRetry(operation, lastException, retryCount++));
  // this point is only reached if the operation failed more than
  // the allowed retry count
  throw translateException(operation, key, lastException);
}
 
开发者ID:SparkTC,项目名称:stocator,代码行数:26,代码来源:COSBlockOutputStream.java

示例9: doUploadMultipart

import com.amazonaws.services.s3.model.PartETag; //导入依赖的package包/类
protected PartETag doUploadMultipart(S3BlobStore blobStore, String bucketName, String blobName, String uploadId, InputStream is,
        int length, boolean lastPart) throws AmazonS3Exception {
    UploadPartRequest request = new UploadPartRequest()
    .withBucketName(bucketName)
    .withKey(blobName)
    .withUploadId(uploadId)
    .withPartNumber(multipartChunks)
    .withInputStream(is)
    .withPartSize(length)
    .withLastPart(lastPart);

    UploadPartResult response = blobStore.client().uploadPart(request);
    return response.getPartETag();

}
 
开发者ID:justor,项目名称:elasticsearch_my,代码行数:16,代码来源:DefaultS3OutputStream.java

示例10: doUploadMultipart

import com.amazonaws.services.s3.model.PartETag; //导入依赖的package包/类
@Override
protected PartETag doUploadMultipart(S3BlobStore blobStore, String bucketName, String blobName, String uploadId, InputStream is, int length, boolean lastPart) throws AmazonS3Exception {
    try {
        long copied = Streams.copy(is, out);
        if (copied != length) {
            throw new AmazonS3Exception("Not all the bytes were copied");
        }
        return new PartETag(numberOfUploadRequests++, RandomizedTest.randomAsciiOfLength(50));
    } catch (IOException e) {
        throw new AmazonS3Exception(e.getMessage());
    }
}
 
开发者ID:justor,项目名称:elasticsearch_my,代码行数:13,代码来源:MockDefaultS3OutputStream.java

示例11: close

import com.amazonaws.services.s3.model.PartETag; //导入依赖的package包/类
@Override
public synchronized void close() throws IOException {
  if (closed) {
    return;
  }
  closed = true;
  try {
    if (multiPartUpload == null) {
      putObject();
    } else {
      if (buffer.size() > 0) {
        //send last part
        multiPartUpload.uploadPartAsync(new ByteArrayInputStream(buffer
            .toByteArray()), buffer.size());
      }
      final List<PartETag> partETags = multiPartUpload
          .waitForAllPartUploads();
      multiPartUpload.complete(partETags);
    }
    statistics.incrementWriteOps(1);
    // This will delete unnecessary fake parent directories
    fs.finishedWrite(key);
    if (LOG.isDebugEnabled()) {
      LOG.debug("Upload complete for bucket '{}' key '{}'", bucket, key);
    }
  } finally {
    buffer = null;
    super.close();
  }
}
 
开发者ID:naver,项目名称:hadoop,代码行数:31,代码来源:S3AFastOutputStream.java

示例12: MultiPartUpload

import com.amazonaws.services.s3.model.PartETag; //导入依赖的package包/类
public MultiPartUpload(String uploadId) {
  this.uploadId = uploadId;
  this.partETagsFutures = new ArrayList<ListenableFuture<PartETag>>();
  if (LOG.isDebugEnabled()) {
    LOG.debug("Initiated multi-part upload for bucket '{}' key '{}' with " +
        "id '{}'", bucket, key, uploadId);
  }
}
 
开发者ID:naver,项目名称:hadoop,代码行数:9,代码来源:S3AFastOutputStream.java

示例13: complete

import com.amazonaws.services.s3.model.PartETag; //导入依赖的package包/类
public void complete(List<PartETag> partETags) {
  if (LOG.isDebugEnabled()) {
    LOG.debug("Completing multi-part upload for key '{}', id '{}'", key,
        uploadId);
  }
  final CompleteMultipartUploadRequest completeRequest =
      new CompleteMultipartUploadRequest(bucket, key, uploadId, partETags);
  client.completeMultipartUpload(completeRequest);

}
 
开发者ID:naver,项目名称:hadoop,代码行数:11,代码来源:S3AFastOutputStream.java

示例14: uploadObject

import com.amazonaws.services.s3.model.PartETag; //导入依赖的package包/类
/**
 * Used for performance testing purposes only.  Hence package private.
 * This method is subject to removal anytime without notice.
 */
CompleteMultipartUploadResult uploadObject(final UploadObjectRequest req)
        throws IOException, InterruptedException, ExecutionException {
    // Set up the pipeline for concurrent encrypt and upload
    // Set up a thread pool for this pipeline
    ExecutorService es = req.getExecutorService();
    final boolean defaultExecutorService = es == null;
    if (es == null)
        es = Executors.newFixedThreadPool(clientConfiguration.getMaxConnections());
    UploadObjectObserver observer = req.getUploadObjectObserver();
    if (observer == null)
        observer = new UploadObjectObserver();
    // initialize the observer
    observer.init(req, this, this, es);
    // Initiate upload
    observer.onUploadInitiation(req);
    final List<PartETag> partETags = new ArrayList<PartETag>();
    MultiFileOutputStream mfos = req.getMultiFileOutputStream();
    if (mfos == null)
        mfos = new MultiFileOutputStream();
    try {
        // initialize the multi-file output stream
        mfos.init(observer, req.getPartSize(), req.getDiskLimit());
        // Kicks off the encryption-upload pipeline;
        // Note mfos is automatically closed upon method completion.
        putLocalObject(req, mfos);
        // block till all part have been uploaded
        for (Future<UploadPartResult> future: observer.getFutures()) {
            UploadPartResult partResult = future.get();
            partETags.add(new PartETag(partResult.getPartNumber(), partResult.getETag()));
        }
    } finally {
        if (defaultExecutorService)
            es.shutdownNow();   // shut down the locally created thread pool
        mfos.cleanup();       // delete left-over temp files
    }
    // Complete upload
    return observer.onCompletion(partETags);
}
 
开发者ID:IBM,项目名称:ibm-cos-sdk-java,代码行数:43,代码来源:AmazonS3Client.java

示例15: CompleteMultipartUpload

import com.amazonaws.services.s3.model.PartETag; //导入依赖的package包/类
public CompleteMultipartUpload(String uploadId, AmazonS3 s3,
        PutObjectRequest putObjectRequest, List<Future<PartETag>> futures,
        List<PartETag> eTagsBeforeResume, ProgressListenerChain progressListenerChain,
        UploadMonitor monitor) {
    this.uploadId = uploadId;
    this.s3 = s3;
    this.origReq = putObjectRequest;
    this.futures = futures;
    this.eTagsBeforeResume = eTagsBeforeResume;
    this.listener = progressListenerChain;
    this.monitor = monitor;
}
 
开发者ID:IBM,项目名称:ibm-cos-sdk-java,代码行数:13,代码来源:CompleteMultipartUpload.java


注:本文中的com.amazonaws.services.s3.model.PartETag类示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。