17

Rails 4 - Ruby 2.2.2 - 亚马逊 AWS S3 - 蜻蜓 1.0.12 - 蜻蜓-s3_data_store 1.2 - 雾-aws 0.10.0

大约 99% 的时间我们没有问题。这个问题通常只发生在使用率很高的时候,但我注意到它也发生在几乎没有用户的时候。引发错误的行:

 # excon/lib/excon/socket.rb
 # line 100 inside the connection method.
 addrinfo = ::Socket.getaddrinfo(*args)

错误发生在应用程序的任何地方。有时当没有远程连接时会出现错误。- 我不再能够验证这一点。

我使用 Rails 记录器来捕获传入的参数,通过和失败之间似乎没有区别。这里有些例子:

 # PASS
 ["s3.amazonaws.com", 443, 0, 1, nil, nil, false]
 ["mybucket.s3.amazonaws.com", 443, 0, 1, nil, nil, false]

 # FAIL
 ["mybucket.s3-us-west-1.amazonaws.com", 443, 0, 1, nil, nil, false]

我遇到了几个论坛,这些论坛让我相信 excon gem 需要更新。我将 Excon gem 从 0.45.4 升级到了 0.51.0。除此之外,我还将 Fog gem 从 1.36.0 更新到 1.38.0。

升级后,错误从“getaddrinfo: Name or service not known (SocketError)”变为“Excon::Error::Socket: getaddrinfo: No address associated with hostname (SocketError)”

为失败的响应捕获的 url 与通过的 url 之一不同。我会进一步研究这个。

更新:

蜻蜓初始化程序指定与失败的路径相同的路径,并且因为 url_host 覆盖了默认功能,我决定将其删除。

 # myapp/config/initializers/dragonfly.rb
 ...
 url_host: 'mybucket.s3-us-west-1.amazonaws.com'

这导致没有任何变化。仍然使用相同的 url,并且是唯一失败的。

4

2 回答 2

1

我也有这个错误。就我而言,罪魁祸首要么是服务器负载(文件上传缓慢),要么是文件名中的特殊字符。由于您在低使用时间也会看到这一点,因此您可能需要查看人们上传的文件名。对我来说,错误通常发生在有人上传文件名中带有德语变音符号(ä,ö,ü,ß)的文件时。

因此,请尝试上传名称中包含某些特殊字符的文件,并告诉我们这是否忠实地重现了错误。

如果是这种情况,那么只需转义特殊字符或以不同的方式命名文件。以下是特殊字符问题的描述:https ://github.com/markevans/dragonfly-s3_data_store/issues/6 。

于 2016-12-30T18:37:17.370 回答
0

它可能无法解决您的问题,但我在两种情况下看到过类似的情况-

  1. 防火墙限制了我的系统配置的端口。
  2. 我的授权/身份验证凭据错误/过时。
于 2017-02-22T07:27:05.137 回答