2017-09-18 8 views
0

람다 자바 함수를 사용하여 S3 객체의 이전 버전의 메타 데이터를 검색하는 동안 허용되지 않는 405 메소드가 발생합니다. 람다에서S3가 이전 버전의 객체에 대한 메타 데이터를 얻습니다.

AmazonS3 amazonS3 = getAmazonS3(); 
GetObjectRequest getObjectRequest = new GetObjectRequest(bucket, templateKey, versionId); 
ObjectMetadata objectMetadata = amazonS3.getObject(getObjectRequest).getObjectMetadata(); // Exception thrown at this line 

public AmazonS3 getAmazonS3() { 
    String region = PropertyManager.getValue(PropertyKey.AWS_REGION.getKey(stage)); 
    return AmazonS3ClientBuilder.standard().withRegion(region) 
       .withCredentials(new EnvironmentVariableCredentialsProvider()).build(); 
    } 

스택 추적 :

The specified method is not allowed against this resource. (Service: Amazon S3; Status Code: 405; Error Code: MethodNotAllowed; Request ID: 1D12DDA5F0493282): com.amazonaws.services.s3.model.AmazonS3Exception 
com.amazonaws.services.s3.model.AmazonS3Exception: The specified method is not allowed against this resource. (Service: Amazon S3; Status Code: 405; Error Code: MethodNotAllowed; Request ID: 1D12DDA5F0493282), S3 Extended Request ID: jTNnAl8ifgsUlPMV0GEHAEVBtWwjTprEJy45C9BMJ5kTk/Qn8Pne8/ZM/tH27ZoeUtHrd1NeuyQ= 
    at com.amazonaws.http.AmazonHttpClient$RequestExecutor.handleErrorResponse(AmazonHttpClient.java:1588) 
    at com.amazonaws.http.AmazonHttpClient$RequestExecutor.executeOneRequest(AmazonHttpClient.java:1258) 
    at com.amazonaws.http.AmazonHttpClient$RequestExecutor.executeHelper(AmazonHttpClient.java:1030) 
    at com.amazonaws.http.AmazonHttpClient$RequestExecutor.doExecute(AmazonHttpClient.java:742) 
    at com.amazonaws.http.AmazonHttpClient$RequestExecutor.executeWithTimer(AmazonHttpClient.java:716) 
    at com.amazonaws.http.AmazonHttpClient$RequestExecutor.execute(AmazonHttpClient.java:699) 
    at com.amazonaws.http.AmazonHttpClient$RequestExecutor.access$500(AmazonHttpClient.java:667) 
    at com.amazonaws.http.AmazonHttpClient$RequestExecutionBuilderImpl.execute(AmazonHttpClient.java:649) 
    at com.amazonaws.http.AmazonHttpClient.execute(AmazonHttpClient.java:513) 
    at com.amazonaws.services.s3.AmazonS3Client.invoke(AmazonS3Client.java:4187) 
    at com.amazonaws.services.s3.AmazonS3Client.invoke(AmazonS3Client.java:4134) 
    at com.amazonaws.services.s3.AmazonS3Client.getObject(AmazonS3Client.java:1385) 
    at com.ghx.templateengine.template.GetTemplateVersions.handleRequest(GetTemplateVersions.java:66) 
+0

메타 데이터가 아니라 개체 자체를 가져 오는 동안 동일한 예외가 발생합니까? –

+0

versionId를 지정하지 않을 때 객체를 가져올 수 있습니다. 내가 지정한 경우 비슷한 오류가 발생합니다. –

답변

0

S3 객체의 이전 버전의 몇 삭제 마커했다. AWS 지원은 삭제 마커 인 객체를 헤드에 놓으려고하면 405 오류가 발생 함을 알립니다.