使用erlcloud列出S3存储桶时出现超时错误

时间:2014-07-27 00:11:25

标签: amazon-web-services amazon-s3 erlang elixir

我尝试在我的应用中使用erlcloud库进行S3上传。作为测试,我试图通过iex控制台来列出存储桶:

iex(4)> s3 = :erlcloud_s3.new("KEY_ID", "SECRET_KEY")
...
iex(5)> :erlcloud_s3.list_buckets(s3)
** (ErlangError) erlang error: {:aws_error, {:socket_error, :timeout}}
    (erlcloud) src/erlcloud_s3.erl:909: :erlcloud_s3.s3_request/8
    (erlcloud) src/erlcloud_s3.erl:893: :erlcloud_s3.s3_xml_request/8
    (erlcloud) src/erlcloud_s3.erl:238: :erlcloud_s3.list_buckets/1

我已经检查过inetssslerlcoud都已启动,我知道凭据工作正常,因为我已经在与irb中的Ruby库类似的方式。

我尝试使用更长的超时配置它,但无论我设置多高,我仍然会收到此错误。

有什么想法吗?或者我可以采取哪些方法来调试它?

1 个答案:

答案 0 :(得分:8)

我可以模拟相同的错误,并可以通过用单引号替换双引号来解决它。

> iex(4)> s3 = :erlcloud_s3.new('KEY_ID', 'SECRET_KEY')
> iex(5)> :erlcloud_s3.list_buckets(s3)

假设使用了双引号,可能是由字符串和字符列表之间的类型不匹配引起的。