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

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

ただいまの
回答率

90.00%

(rails)carrierwaveでS3にアップロードする際のエラー(SocketError)

受付中

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 59

hasegawa-kei

score 0

carrierwaveでS3に画像をアップロードしたい(rails)

carrierwaveでS3に画像をアップロードを実装中にエラーが発生し、どうしても解決できないため質問させていただきます。
お力を貸していただきたいです。

参考サイト1
※上手くいかなかったので、いろいろなサイトを参考しています。

開発環境:docker
ruby:2.5.1
rails:5.2.3> 

発生している問題・エラーメッセージ

画像をcreateする際に「getaddrinfo: Name or service not known (SocketError)」とエラーが発生します。
イメージ説明

carrierwave.rb

CarrierWave.configure do |config|
  # if Rails.env.production?
    # config.storage :fog
  config.fog_provider = 'fog/aws'
  config.fog_directory  = ENV['AWS_S3_BUCKET']
  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_S3_REGION'],
    path_style: true
  }
  config.cache_storage = :fog
  config.fog_public     = false
  config.fog_attributes = { cache_control: "max-age=#{365.days.to_i}" }
  # else
  #   config.storage :file
  #   config.enable_processing = false if Rails.env.test?
  # end
end

CarrierWave::SanitizedFile.sanitize_regexp = /[^[:word:]\.\-\+]/

picture_uploader.rb

class PictureUploader < CarrierWave::Uploader::Base

  include CarrierWave::RMagick

  storage :fog

  def store_dir
    "uploads/#{model.id}"
  end


  process resize_to_limit: [1280, 670]

  version :thumb do
    process :resize_to_limit => [300, 300]
  end

  version :thumb50 do
    process :resize_to_limit => [100, 100]
  end


  def extension_whitelist
   %w(jpg jpeg png)
  end


  def filename
    "#{secure_token(10)}.#{file.extension}" if original_filename.present?
  end

  protected

  def secure_token(length = 16)
    var = :"@#{mounted_as}_secure_token"
    model.instance_variable_get(var) or model.instance_variable_set(var, SecureRandom.hex(length / 2))
  end
end

Gemfile

gem 'carrierwave'
gem 'rmagick'
gem 'fog-aws'
gem 'fog',  '1.41'
gem 'dotenv-rails'
gem 'mini_magick'

recipes_controller.rb

class RecipesController < ApplicationController
  before_action :set_target_recipe, only: %i[show edit update destroy]
  before_action :authenticate_user!


  def new
    @recipe = Recipe.new
  end

  def create
    recipe = current_user.recipes.create(recipe_params)
    if recipe.save
      flash[:notice] = "「#{recipe.title}」を作成しました。"
      redirect_to recipe
    else
      flash[:recipe] = recipe
      flash[:error_messages] = recipe.errors.full_messages
      redirect_back(fallback_location: recipe)
    end

  end

  def index

    @recipes = params[:tag_id].present? ? Tag.find(params[:tag_id]).recipes : Recipe.all
    @recipes = @recipes.page(params[:page])
  end

  def show
    @comment = Comment.new(recipe_id: @recipe.id)
    @comments = @recipe.comments
    @like = Like.new
  end

  def edit
  end

  def update
    if @recipe.update(recipe_params)
      redirect_to @recipe
    else
      flash[:recipe] = @recipe
      flash[:error_messages] = @recipe.errors.full_messages
      redirect_back(fallback_location: @recipe)
    end
  end

  def destroy
    @recipe.destroy

    redirect_to recipes_path, flash: { notice: "「#{@recipe.title}」が削除されました。"}
  end

  private
  def recipe_params
    params.require(:recipe).permit(:title, :picture, :picture_cache , :body, tag_ids: [])
  end

  def set_target_recipe
    @recipe = Recipe.find(params[:id])
  end

end


※recipe_paramsのpicture_cacheを削除しても,エラーが発生します。

.env

AWS_ACCESS_KEY_ID='////'
AWS_SECRET_ACCESS_KEY='////'
AWS_S3_REGION='us-east-2'
AWS_S3_BUCKET='////'

recipe.rb

class Recipe < ApplicationRecord
  mount_uploader :picture, PictureUploader
....

Dockerfile

FROM ruby:2.4.5
RUN apt-get update -qq && apt-get install -y build-essential nodejs
RUN curl -sL https://deb.nodesource.com/setup_10.x | bash - \
    && apt-get install -y nodejs
RUN mkdir /yumyumkitchen
WORKDIR /app
COPY Gemfile /app/Gemfile
COPY Gemfile.lock /app/Gemfile.lock
RUN bundle install
COPY . /app

docker-compose.yml

version: '3'
services:

  web:
    build: .
    command: bundle exec rails s -p 3000 -b '0.0.0.0'
    volumes:
      - .:/app
    ports:
      - 3000:3000
    env_file: .env
    depends_on:
      - db
    tty: true
    stdin_open: true
  db:
    image: mysql:5.7
    volumes:
      - db-volume:/var/lib/mysql
    environment:
      MYSQL_ROOT_PASSWORD: password
volumes:
  db-volume:

試したこと

docker-compose buildをし直したりしていますが...

12/1修正後carrierwave.rb

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


CarrierWave.configure do |config|
  config.storage :fog
  config.fog_provider = 'fog/aws'
  config.fog_directory  = ENV['AWS_S3_BUCKET']
  config.asset_host = 'https://s3.amazonaws.com/railspotoforio'
  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_S3_REGION'],
    path_style: true
  }
  config.cache_storage = :fog
  config.fog_public     = false
  config.fog_attributes = { cache_control: "max-age=#{365.days.to_i}" }

end

CarrierWave::SanitizedFile.sanitize_regexp = /[^[:word:]\.\-\+]/
  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 1

0

推測で、あくまでも可能性のお話をしてみます。


以下の記事を見た感じだと、そのエラーは、hostが見つからないときに発生するようです。

https://github.com/puma/puma/issues/1623

私は以下の記事の通りに設定を書いているのですが、

[Rails] CarrierWave 経由で AWS S3 にファイルをアップロードする際の設定

この設定と比較すると、

config.storage :fog
config.asset_host = 'https://s3.amazonaws.com/バケット名'

の部分が異なっているので、試しにここを合わせてみてはいかがでしょうか?

config.storage によって、保存先をローカルディレクトリではなくて外部に設定し、config.asset_host によって、外部storageのURLを指定していると思いますので、試す価値はあるとは思います。

※見たところ、storageのホストURLが一切指定されていないので、そのせいでどこに保存したらいいかわからなくてエラーが出ていそうな気がします。

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2019/12/01 22:49

    ご回答いただきありがとうございます。
    ご指摘の通り、carrierwave.rbを修正しました。
    しかしながらエラーメッセージは変わりませんでした。
    他に確認すべき箇所はあるでしょうか。

    キャンセル

  • 2019/12/03 12:34

    他には docker の host 設定が怪しそうです。

    回答にも書いていますが、
    https://github.com/puma/puma/issues/1623
    こちらのURLを見る限り、railsではなくて、OSのネットワーク設定に問題がある可能性もあるようです。

    キャンセル

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

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