在/app/config/storage.yml中找不到Active Storage配置(RuntimeError)

时间:2018-10-24 21:46:50

标签: ruby-on-rails amazon-web-services heroku crash rails-activestorage

我的应用程序已部署到Heroku,但每次都崩溃。我不知道为什么我已经在Heroku上为生产中的应用设置了Carrierwave,雾和aws,然后就可以了。试图遵循相同的步骤,并且我得到了h10错误代码。在rails控制台中,它具体说:

  

/app/vendor/bundle/ruby/2.3.0/gems/activestorage-5.2.1/lib/active_storage/engine.rb:76:in   `中的块(2个级别):找不到活动存储   /app/config/storage.yml中的配置(RuntimeError)

storage.yml 

test:
  service: Disk
  root: <%= Rails.root.join("tmp/storage") %>

local:
  service: Disk
  root: <%= Rails.root.join("storage") %>


# Use rails credentials:edit to set the AWS secrets (as aws:access_key_id|secret_access_key)
# amazon:
amazon:
  service: S3
  access_key_id: "S3_KEY"
  secret_access_key: "S3_SECRET"
  region: "us-east-1"
  bucket: "books4reviews"

production.rb

  config.active_storage.service = :amazon 

carrierwave.rb

CarrierWave.configure do |config|

config.fog_provider = 'fog/aws'

config.fog_credentials = {
  provider: 'AWS',
  aws_access_key_id: ENV['S3_KEY'],
  aws_secret_access_key: ENV['S3_SECRET'],
  region: 'us-east-1'
}
config.fog_directory  = 'books4reviews'
config.fog_public = false
config.storage = :fog
end

puma.rb

threads_count = ENV.fetch("RAILS_MAX_THREADS") { 5 }
threads threads_count, threads_count

    port        ENV.fetch("PORT") { 3000 }

   environment ENV.fetch("RAILS_ENV") { "development" }

  plugin :tmp_restart

Procfile

web: bundle exec puma -C config/puma.rb

avatar_uploader.rb

class AvatarUploader < CarrierWave::Uploader::Base
  # Include RMagick or MiniMagick support:
  # include CarrierWave::RMagick
  # Choose what kind of storage to use for this uploader:
  include CarrierWave::MiniMagick

  storage :fog

  process resize_to_fit: [500,500]

  version :small do
    process resize_to_fill: [200, 200]
  end

  version :medium do

      # change the word 'fit' to 'fill'
      process resize_to_fill: [400,600]
  end

  version :large do
    process resize_to_fill: [1000,1000]
  end

  version :thumb do
    process resize_to_fill: [50, 50]
  end

  def store_dir
    "uploads/#{model.class.to_s.underscore}/#{mounted_as}/#{model.id}"
  end

  def extension_white_list
    %w(jpg jpeg gif png)
  end

end

我已经在终端的heroku配置变量中为aws凭证设置了env变量。您能告诉我为什么出现此活动存储错误吗?谢谢

2 个答案:

答案 0 :(得分:14)

我在部署最近升级的 Rails 应用时遇到了同样的问题。应用程序从Rails 5 升级到Rails 6。但是,当我尝试部署到 Heroku 时,出现以下错误:

2021-02-12T17:32:33.404828+00:00 app[web.1]: ! Unable to load application: RuntimeError: Couldn't find Active Storage configuration in /app/config/storage.yml
2021-02-12T17:32:33.404874+00:00 app[web.1]: bundler: failed to load command: puma (/app/vendor/bundle/ruby/2.7.0/bin/puma)
2021-02-12T17:32:33.404958+00:00 app[web.1]: RuntimeError: Couldn't find Active Storage configuration in /app/config/storage.yml

这是我修复它的方法

我检查了我的应用程序的 config 目录,发现它没有 config/storage.yml 文件。我所要做的就是创建文件,并将 Rails 6 应用程序附带的 vanilla 模板复制到文件中:

test:
  service: Disk
  root: <%= Rails.root.join("tmp/storage") %>

local:
  service: Disk
  root: <%= Rails.root.join("storage") %>

# Use rails credentials:edit to set the AWS secrets (as aws:access_key_id|secret_access_key)
# amazon:
#   service: S3
#   access_key_id: <%= Rails.application.credentials.dig(:aws, :access_key_id) %>
#   secret_access_key: <%= Rails.application.credentials.dig(:aws, :secret_access_key) %>
#   region: us-east-1
#   bucket: your_own_bucket

# Remember not to checkin your GCS keyfile to a repository
# google:
#   service: GCS
#   project: your_project
#   credentials: <%= Rails.root.join("path/to/gcs.keyfile") %>
#   bucket: your_own_bucket

# Use rails credentials:edit to set the Azure Storage secret (as azure_storage:storage_access_key)
# microsoft:
#   service: AzureStorage
#   storage_account_name: your_account_name
#   storage_access_key: <%= Rails.application.credentials.dig(:azure_storage, :storage_access_key) %>
#   container: your_container_name

# mirror:
#   service: Mirror
#   primary: local
#   mirrors: [ amazon, google, microsoft ]

这次我部署一切正常。

注意:您可以根据您的存储配置修改文件内容

仅此而已。

我希望这会有所帮助

答案 1 :(得分:0)

这可能无法解决您的问题,但是我使用的是“ .yaml”而不是“ .yml”,因为我必须手动手动创建文件“ /config/storage.yml”并输入错误。

希望这对某人有帮助,因为我找不到此错误的很多结果。

仅供参考,我认为生成器没有创建storage.yml文件,因为我最初是在Rails 5.1上,然后又升级到5.2