6

为我们的上传者使用carrierwave,我们每周都会从我们的生产应用程序中收到几个Excon错误。例如:

Excon::Errors::BadRequest: Expected(200) <=> Actual(400 Bad Request) excon.error.response :body => "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<Error><Code>IncompleteBody</Code><Message>The request body terminated unexpectedly</Message>

我们已经开始将上传过程包装在一个重试块中,并且在再次尝试后它似乎总是可以正常工作,但我想知道是否有更好的解决方案,因为这在一段时间后变得笨拙。在我看来,这些错误应该在较低级别进行处理。有没有更好的方法来处理这些问题?

这是我们的生产配置:

config.storage = :fog
config.root = Dir.tmpdir
config.cache_dir = 'carrierwave'
config.fog_credentials = {
  provider: 'AWS',
  aws_access_key_id: ENV['AWS_ACCESS_KEY_ID'],
  aws_secret_access_key: ENV['AWS_ACCESS_KEY'],
}

config.fog_directory = ENV['AWS_S3_BUCKET']
config.fog_public = false
config.fog_authenticated_url_expiration = 7.days.to_i

config.enable_processing = true

我们正在使用 gem 版本:

fog (1.27.0)
carrierwave (0.10.0)
excon (0.43.0)
4

1 回答 1

3

在我这样编写初始化程序后,它又开始工作了,在克服了几个问题之后,我认为 AWS 端点已经改变:

CarrierWave.configure do |config|
  config.fog_credentials = {
      :provider               => 'AWS',
      :aws_access_key_id      => ENV['S3_KEY'],
      :aws_secret_access_key  => ENV['S3_SECRET'],
      :endpoint               => "https://s3.amazonaws.com",
      :region                 => ENV['S3_REGION'] 
  }
  config.fog_directory  = ENV['S3_BUCKET']
end

另外,我认为我的区域是“us-west-2”,查看我的 AWS 管理控制台,但是当我更改为“eu-west-1”时它才开始工作。

后来我意识到指定那个端点不是一个好主意,实际上最好把它留在这种情况下。无论如何,更改为 lobati 指出的carrierwave-aws 解决了这个问题。

于 2015-02-03T17:13:55.877 回答