Ben*_*Ben 5 ruby amazon-web-services amazon-glacier
Glacier 的 amazon 文档似乎没有包含任何 Ruby 示例,而且文档本身相当稀少。
我想我需要实例化一个 Glacier Client 对象,然后使用 upload_multipart_part 方法来访问 Glacier API,但不确定如何处理要传递给 upload_multipart_part 的参数。如何使用 ruby 计算 AWS 正在寻找的校验和?什么是upload_id?
更新
通过阅读亚马逊的文档了解了大部分内容。他们似乎没有任何 ruby 代码示例,代码示例的 github repo 不包括 Glacier。但是通过查看原始 API 文档和一些 Java 和 PHP 示例,看起来我会这样做:
client = AWS::Glacier::Client.new(access_key_id: ACCESS_KEY_ID, secret_access_key: SECRET_ACCESS_KEY)
resp = client.initiate_multipart_upload(account_id: ACCOUNT_ID, vault_name: 'My Vault', archive_description: "Backup of some stuff", part_size: PART_SIZE_IN_BYTES)
Run Code Online (Sandbox Code Playgroud)
如果一切顺利,亚马逊 API 响应应该包含一个唯一的 upload_id,然后我将在使用 client.upload_multipart_part() 的后续调用中使用它。
我猜校验和可以这样计算:
Digest::SHA256.file(file_to_upload).hexdigest
Run Code Online (Sandbox Code Playgroud)
更新 2
这个好像已经解决了:
对于其他感兴趣的人来说,此链接很有帮助,几乎涵盖了您需要的大部分内容:
http://www.spacevatican.org/2012/9/4/using-glacier-with-fog/
它并没有真正提供有关如何实例化冰川对象的所有详细信息:
glacier = Fog::AWS::Glacier.new({
:aws_access_key_id => YOUR_ACCESS_KEY_ID,
:aws_secret_access_key => YOUR_SECRET_ACCESS_KEY
})
Run Code Online (Sandbox Code Playgroud)