Aws-sdk gem'无法在远程服务器上加载此类文件'错误,但不能在本地加载

时间:2015-05-05 15:55:25

标签: ruby-on-rails ruby ruby-on-rails-4 paperclip aws-sdk

这与other questions非常相似,但这些解决方案看似不适用于此处。

我可以在本地生产模式下运行我的rails应用程序,但在远程服务器上它失败并显示有关aws-sdk gem的消息:

A LoadError occurred in images#index:

cannot load such file -- aws-sdk (You may need to install the aws-sdk gem)
app/controllers/images_controller.rb:9:in `block (2 levels) in index'
aws-sdk正在使用

Paperclip 4.2.0,目前只与aws-sdk 1.x(无版本2)集成。 require 'aws-sdk'不在我自己的代码中。违规行为代码:

@images = @viewable.images
respond_to do |format|
  format.html {}
  #line 9:
  format.json {render json: @images, root: false, each_serializer: ImageSerializer}
end

到目前为止我调查的内容如下。

远程与本地配置

这似乎最有可能是原因。也许我的服务器找不到一些关键的配置,因此aws-sdk无法初始化。以下是我的配置的工作原理:

根据this page配置S3。我完全按照教程,除了稍微改变以适应多个生产模式服务器:

config / application.yml(由figaro加载到ENV的值):

production:
  s3_bucket: 'mybucket'

development:
  s3_bucket: 'mybucket'

config / aws.yml(由aws-sdk自动加载):

development:
  access_key_id: AK_MY_ID
  secret_access_key: MYSECRET
production:
  access_key_id: AK_MY_ID
  secret_access_key: MYSECRET

摘自config / environments / production.rb:

config.paperclip_defaults = {
  storage: :s3,
  s3_credentials: {
    bucket: ENV['s3_bucket']
  }
}

据我所知,每个部署都正确创建了每个yml文件的符号链接:

deployer:~/apps/myapp/releases/20150505130826$ ll config/
lrwxrwxrwx  1 deployer deployer    53 May  5 13:08 application.yml -> /home/deployer/apps/myapp/shared/config/application.yml
lrwxrwxrwx  1 deployer deployer    45 May  5 13:08 aws.yml -> /home/deployer/apps/myapp/shared/config/aws.yml

我检查过的其他事情:

我怀疑这个控制器有问题

访问同一模型的其他操作和控制器也会失败,并且仅在远程服务器上失败。

宝石安装看起来不错

在几个月的部署过程中,我遇到了其他宝石丢失的问题。 Bundler没有输出说安装失败。来自capistrano部署输出:

 ~/.rvm/bin/rvm ruby-2.1.5@myapp do bundle install --path /home/deployer/apps/myapp/shared/bundle --without development test --deployment --quiet as deployer@myapp.com
DEBUG [c43674b8] Command: cd /home/deployer/apps/myapp/releases/20150505130826 && ~/.rvm/bin/rvm ruby-2.1.5@myapp do bundle install --path /home/deployer/apps/myapp/shared/bundle --without development test --deployment --quiet
INFO [c43674b8] Finished in 3.582 seconds with exit status 0 (successful).

从shell我可以检查gem的安装位置:

~/apps/myapp/releases/20150505130826$ ~/.rvm/bin/rvm ruby-2.1.5@myapp do bundle show aws-sdk
/home/deployer/apps/myapp/shared/bundle/ruby/2.1.0/gems/aws-sdk-1.64.0

在rails控制台中:

2.1.5 :001 > Gem.loaded_specs['aws-sdk'].full_gem_path
 => "/home/deployer/apps/myapp/shared/bundle/ruby/2.1.0/gems/aws-sdk-1.64.0"

所以Rails 似乎知道了这个宝石。

AWS凭证看起来不错

相同的凭据在我的本地计算机上完美运行(在开发模式和生产模式下)。凭据也可以在远程服务器上使用s3cmd。当我故意在本地计算机上将它们设置为不正确的值时,我从AWS获得了Access Denied错误,而不是像这样的整个操作。

我还能在哪里寻找问题?

1 个答案:

答案 0 :(得分:0)

我尝试使用gem 'aws-sdk-v1'。这对我的aws项目很有用。