質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

89.23%

Rails6のアプリをherokuにデプロイしたが、画像アップロード機能で使うimageカラムが消失する

解決済

回答 1

投稿

  • 評価
  • クリップ 1
  • VIEW 390

jaguarundi

score 19

Rails6でアプリを作っています。
画像投稿機能をcarrierwaveで作成し、画像を投稿する機能をつけました。
ローカルでは問題なくuploaderディレクトリに保存されていますが、herokuでは画像の保持ができないということで、AWSのS9を利用してアップロード機能を作っているのですが、'We're sorry, but something went wrong'が出るばかりでうまくいきません。

require 'carrierwave/storage/abstract'
require 'carrierwave/storage/file'
require 'carrierwave/storage/fog'

CarrierWave.configure do |config|
  if Rails.env.production?
    config.storage :fog
    config.fog_provider = 'fog/aws'
    config.fog_directory  = 'バケット名'
    config.fog_credentials = {
      provider: 'AWS',
      aws_access_key_id: ENV['AWS_ACCESS_KEY_ID'],
      aws_secret_access_key: ENV['AWS_SECRET_ACCESS_KEY'],
      region: ENV['AWS_REGION'],
      path_style: true
    }
  else
    config.storage :file
    config.enable_processing = false if Rails.env.test?
  end
end

CarrierWave::SanitizedFile.sanitize_regexp = /[^[:word:]\.\-\+]/
class ImageUploader < CarrierWave::Uploader::Base
  # Include RMagick or MiniMagick support:
   include CarrierWave::RMagick
  # include CarrierWave::MiniMagick

  # Choose what kind of storage to use for this uploader:

  if Rails.env.production?
    storage :fog
  else
    storage :file
  end

  process :convert => 'jpg'

  process resize_to_limit: [500, 500]
  # Override the directory where uploaded files will be stored.
  # This is a sensible default for uploaders that are meant to be mounted:
  def store_dir
    "uploads/#{model.class.to_s.underscore}/#{mounted_as}/#{model.id}"
  end

  # Provide a default URL as a default if there hasn't been a file uploaded:
  # def default_url(*args)
  #   # For Rails 3.1+ asset pipeline compatibility:
  #   # ActionController::Base.helpers.asset_path("fallback/" + [version_name, "default.png"].compact.join('_'))
  #
  #   "/images/fallback/" + [version_name, "default.png"].compact.join('_')
  # end

  # Process files as they are uploaded:
  # process scale: [200, 300]
  #
  # def scale(width, height)
  #   # do something
  # end

  # Create different versions of your uploaded files:
   version :thumb do
     process resize_to_fit: [150, 150]
   end

  # Add a white list of extensions which are allowed to be uploaded.
  # For images you might use something like this:
   def extension_whitelist
     %w(jpg jpeg gif png)
   end

  # Override the filename of the uploaded files:
  # Avoid using model.id or version_name here, see uploader/store.rb for details.
   def filename
     "#{secure_token}.jpg" if original_filename
   end

   protected
   def secure_token
     var = :"@#{mounted_as}_secure_token"
     model.instance_variable_get(var) or model.instance_variable_set(var, SecureRandom.uuid)
   end


end
2019-09-28T02:49:21.344383+00:00 app[web.1]: D, [2019-09-28T02:49:21.344324 #4] DEBUG -- : [e2a24180-f823-4e16-b62d-3f5b265bfdbb]    (1.2ms)  ROLLBACK
2019-09-28T02:49:21.344812+00:00 app[web.1]: I, [2019-09-28T02:49:21.344757 #4]  INFO -- : [e2a24180-f823-4e16-b62d-3f5b265bfdbb] Completed 500 Internal Server Error in 14ms (ActiveRecord: 6.7ms | Allocations: 1867)
2019-09-28T02:49:21.345448+00:00 app[web.1]: F, [2019-09-28T02:49:21.345397 #4] FATAL -- : [e2a24180-f823-4e16-b62d-3f5b265bfdbb]
2019-09-28T02:49:21.345450+00:00 app[web.1]: [e2a24180-f823-4e16-b62d-3f5b265bfdbb] ActiveModel::MissingAttributeError (can't write unknown attribute `image`):
2019-09-28T02:49:21.345452+00:00 app[web.1]: [e2a24180-f823-4e16-b62d-3f5b265bfdbb]

やったこと

ローカル環境ではPostモデルにimageカラムがちゃんとdb:migrateで追加されるのですが、heroku run rails consoleでherokuにデプロイしたアプリのPostモデルを確認すると、確かにimageカラムが存在せず、応急処置としてheroku run rails g migration add_image_column_to_posts image:sting→db:migrate:reset
を行っても、相変わらずimageカラムが追加されません。(マイグレーションは成功しているのです)

昨日から何度もトライしてみましたが、We're sorry画面が出続け、一向に進捗がないので質問させていただきました。
Rails初心者&AWSについては皆目見当がつかない状態ですので、お力をお貸しください!

#ローカル環境のPostモデル
[1] pry(main)> Post.column_names
   (51.9ms)  SELECT sqlite_version(*)
=> ["id",
 "user_id",
 "title",
 "body",
 "status",
 "deleted_at",
 "image",
 "created_at",
 "updated_at",
 "anonymous"]
#herokuのPostモデル
[1] pry(main)> Post.column_names
=> ["id",
 "user_id",
 "title",
 "body",
 "status",
 "created_at",
 "updated_at",
 "deleted_at",
 "anonymous"]
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

check解決した方法

0

自己解決しました。
おそらく自前で実装していたFile.binwriteでの画像書き込み機能を削除してcarrierwaveに全て移行したところ、うまく行くようになりました.

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 89.23%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる