2013-03-27 63 views
0

我已經創建了一個新的冰川庫用於開發。我爲工作完成通知安裝了SNS和SQS。冰川檔案檢索 - 無效的金庫名稱

我正在使用AWS的java SDK。我能夠成功地將存檔添加到保管庫,但創建檢索作業時出現錯誤。

我使用的代碼是從SDK

InitiateJobRequest initJobRequest = new InitiateJobRequest() 
     .withVaultName(vaultName) 
     .withJobParameters(new JobParameters().withType("archive-retrieval").withArchiveId(archiveId)); 

我使用相同的代碼在測試和生產,它工作正常,但在發展中,我得到這個錯誤:

Status Code: 400, AWS Service: AmazonGlacier, AWS Request ID: xxxxxxxx, AWS Error Code: InvalidParameterValueException, AWS Error Message: Invalid vault name: arn:aws:glacier:us-west-2:xxxxxxx:vaults/xxxxxx

我知道保管庫名稱是正確的,它存在,因爲我使用相同的名稱來運行添加歸檔作業,它完成正常。

我懷疑保險庫可能會在創建後花費一些時間,然後才允許檢索請求,但我找不到任何文檔來確認這一點。

任何人有類似的問題嗎?或者在您啓動檢索請求之前知道保管庫是否有延遲?

回答

0
try { 
     // Get the S3 directory file. 
     S3Object object = null; 
     try { 
      object = s3.getObject(new GetObjectRequest(s3BucketName, key)); 
     } catch (com.amazonaws.AmazonClientException e) { 
      logger.error("Caught an AmazonClientException"); 
      logger.error("Error Message: " + e.getMessage()); 
      return; 
     } 

     // Show 
     logger.info("\tContent-Type: " 
       + object.getObjectMetadata().getContentType()); 
     GlacierS3Dir dir = GlacierS3Dir.digestS3GlacierDirectory(object 
       .getObjectContent()); 
     logger.info("\tGlacier object ID is " + dir.getGlacierFileID()); 

     // Connect to Glacier 
     ArchiveTransferManager atm = new ArchiveTransferManager(client,credentials); 
     logger.info("\tVault: " + vaultName); 

     // create a name 
     File f = new File(key); 
     String filename = f.getName(); 
     filename = path + filename.replace("dir", "tgz"); 

     logger.info("Downloading to '" + filename 
       + "'. This will take up to 4 hours..."); 
     atm.download(vaultName, dir.getGlacierFileID(), new File(filename)); 
     logger.info("Done."); 

    } catch (AmazonServiceException ase) { 
     logger.error("Caught an AmazonServiceException."); 
     logger.error("Error Message: " + ase.getMessage()); 
     logger.error("HTTP Status Code: " + ase.getStatusCode()); 
     logger.error("AWS Error Code: " + ase.getErrorCode()); 
     logger.error("Error Type:  " + ase.getErrorType()); 
     logger.error("Request ID:  " + ase.getRequestId()); 
    } catch (AmazonClientException ace) { 
     logger.error("Caught an AmazonClientException."); 
     logger.error("Error Message: " + ace.getMessage()); 
    }