我创建了一个用于开发的新Glacier文件库。我为工作完成通知设置了SNS和SQS。
我正在使用AWS的java SDK。我能够成功地将存档添加到Vault中,但是在创建检索作业时出现错误。
我使用的代码来自SDK
InitiateJobRequest initJobRequest = new InitiateJobRequest()
.withVaultName(vaultName)
.withJobParameters(new JobParameters().withType("archive-retrieval").withArchiveId(archiveId));
我在测试和生产中使用相同的代码并且它工作正常,但在开发中我收到此错误:
状态代码:400,AWS服务:AmazonGlacier,AWS请求ID:xxxxxxxx,AWS错误代码:InvalidParameterValueException,AWS错误消息:无效的文件库名称:arn:aws:glacier:us-west-2:xxxxxxx:vaults / xxxxxx
我知道保管库名称是正确的,并且它存在,因为我使用相同的名称来运行添加存档作业,它完成得很好。
我怀疑保险库在创建之后可能会花费一些时间才允许检索请求,但我找不到任何文件来证实这一点。
有人有类似的问题吗?或者在您发起检索请求之前知道保管库是否有延迟?
答案 0 :(得分: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());
}
答案 1 :(得分:0)
错误消息“无效的保管库名称”表示此存档位于其他保管库中。证明链接:https://forums.aws.amazon.com/message.jspa?messageID=446187