AWS MultipartUploadException 对于超过5GB大小的文件。
创始人
2024-11-17 10:00:40
0

在处理超过5GB大小的文件时,可以使用AWS SDK提供的MultipartUpload功能来解决。MultipartUpload可以将大文件分割成多个小部分进行并发上传,并在服务器端进行合并。

下面是一个使用Java SDK的代码示例:

import com.amazonaws.AmazonServiceException;
import com.amazonaws.SdkClientException;
import com.amazonaws.auth.DefaultAWSCredentialsProviderChain;
import com.amazonaws.services.s3.AmazonS3;
import com.amazonaws.services.s3.AmazonS3ClientBuilder;
import com.amazonaws.services.s3.model.InitiateMultipartUploadRequest;
import com.amazonaws.services.s3.model.InitiateMultipartUploadResult;
import com.amazonaws.services.s3.model.PartETag;
import com.amazonaws.services.s3.model.UploadPartRequest;
import com.amazonaws.services.s3.model.UploadPartResult;
import com.amazonaws.services.s3.model.CompleteMultipartUploadRequest;
import com.amazonaws.services.s3.model.CompleteMultipartUploadResult;
import com.amazonaws.services.s3.model.AbortMultipartUploadRequest;

import java.io.File;
import java.util.ArrayList;
import java.util.List;

public class UploadLargeFile {
    public static void main(String[] args) {
        String bucketName = "your-bucket-name";
        String keyName = "your-file-key";
        String filePath = "path-to-your-file";
        int partSize = 5 * 1024 * 1024; // 5MB
        
        AmazonS3 s3Client = AmazonS3ClientBuilder.standard()
                .withCredentials(DefaultAWSCredentialsProviderChain.getInstance())
                .build();

        try {
            // Step 1: Initialize multipart upload
            InitiateMultipartUploadRequest initRequest = new InitiateMultipartUploadRequest(bucketName, keyName);
            InitiateMultipartUploadResult initResponse = s3Client.initiateMultipartUpload(initRequest);
            String uploadId = initResponse.getUploadId();

            // Step 2: Upload parts
            long fileSize = new File(filePath).length();
            long filePosition = 0;
            int partNumber = 1;
            List partETags = new ArrayList<>();

            while (filePosition < fileSize) {
                // Calculate part size
                long partSizeRemaining = fileSize - filePosition;
                int currentPartSize = (int) Math.min(partSize, partSizeRemaining);

                // Upload part
                UploadPartRequest uploadRequest = new UploadPartRequest()
                        .withBucketName(bucketName)
                        .withKey(keyName)
                        .withUploadId(uploadId)
                        .withPartNumber(partNumber)
                        .withFileOffset(filePosition)
                        .withFile(filePath)
                        .withPartSize(currentPartSize);
                UploadPartResult uploadResult = s3Client.uploadPart(uploadRequest);
                partETags.add(uploadResult.getPartETag());

                filePosition += currentPartSize;
                partNumber++;
            }

            // Step 3: Complete multipart upload
            CompleteMultipartUploadRequest completeRequest = new CompleteMultipartUploadRequest(bucketName, keyName, uploadId, partETags);
            CompleteMultipartUploadResult completeResult = s3Client.completeMultipartUpload(completeRequest);
            System.out.println("Upload complete. ETag: " + completeResult.getETag());

        } catch (AmazonServiceException e) {
            // Handle Amazon service errors
            e.printStackTrace();
        } catch (SdkClientException e) {
            // Handle client errors
            e.printStackTrace();
        }

        // Step 4: Abort multipart upload if it fails or is not completed
        s3Client.abortMultipartUpload(new AbortMultipartUploadRequest(bucketName, keyName, uploadId));
    }
}

在上面的示例中,bucketName是S3存储桶的名称,keyName是要上传的文件在存储桶中的键,filePath是要上传的文件路径,partSize是每个上传的部分的大小。可以根据需要调整这些参数。

代码中的注释提供了每个步骤的解释。首先,我们初始化上传,然后根据文件大小将文件分割为多个部分进行上传。最后,我们完成上传并获取ETag。

如果上传失败或没有完成,还提供了一个捕获异常的部分,以便可以中止上传。

请确保您已正确配置AWS SDK的凭据,以便能够访问和上传到S3存储桶中。

相关内容

热门资讯

透视揭露!wepoker模拟器... 透视揭露!wepoker模拟器哪个,we-poker靠谱吗-竟然存在有辅助神器(哔哩哔哩)在进入软件...
透视辅助!hhpoker有没有... 透视辅助!hhpoker有没有作弊辅助,hhpoker是内部控制吗-总是是有辅助软件(哔哩哔哩)1、...
透视普及!aapoker透视插... 透视普及!aapoker透视插件,aapoker万能辅助器-好像一直总是有辅助神器(哔哩哔哩)一、可...
透视解谜!wpk控制牌是真的吗... 透视解谜!wpk控制牌是真的吗,微扑克微乐辅助-真是有辅助神器(哔哩哔哩)1、打开软件启动之后找到中...
透视解谜!wpk透视辅助方法,... 透视解谜!wpk透视辅助方法,wpk德州局透视-本来是有辅助脚本(哔哩哔哩)1、用户打开应用后不用登...
透视普及!wepokerh5破... 透视普及!wepokerh5破解,wepokerplus透视脚本免费-都是一直总是有辅助技巧(哔哩哔...
透视解谜!wepoker黑侠破... 透视解谜!wepoker黑侠破解,wepoker作弊视频-好像一直都是有辅助攻略(哔哩哔哩);1、打...
透视开挂!we-poker辅助... 透视开挂!we-poker辅助,wepoker有辅助器吗-都是存在有辅助脚本(哔哩哔哩)1、辅助软件...
透视详情!wepokerplu... 透视详情!wepokerplus透视脚本免费,wepoker辅助器是真的吗-好像一直总是有辅助方法(...
透视总结!wpk安卓下载辅助,... 透视总结!wpk安卓下载辅助,wpk辅助插件-原来存在有辅助插件(哔哩哔哩)一、游戏安装教程牌型概率...