(rails)carrierwaveでS3にアップロードする際のエラー(SocketError)
- 評価
- クリップ 0
- VIEW 773
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ページの「アクティブ」「注目」タブのフィードに表示されにくくなります。
質問の評価を下げたことを取り消します
この機能は開放されていません
評価を下げる条件を満たしてません
質問の評価を下げる機能の利用条件
この機能を利用するためには、以下の事項を行う必要があります。
- 質問回答など一定の行動
-
メールアドレスの認証
メールアドレスの認証
-
質問評価に関するヘルプページの閲覧
質問評価に関するヘルプページの閲覧
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が一切指定されていないので、そのせいでどこに保存したらいいかわからなくてエラーが出ていそうな気がします。
投稿
-
回答の評価を上げる
以下のような回答は評価を上げましょう
- 正しい回答
- わかりやすい回答
- ためになる回答
評価が高い回答ほどページの上位に表示されます。
-
回答の評価を下げる
下記のような回答は推奨されていません。
- 間違っている回答
- 質問の回答になっていない投稿
- スパムや攻撃的な表現を用いた投稿
評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。
15分調べてもわからないことは、teratailで質問しよう!
- ただいまの回答率 88.34%
- 質問をまとめることで、思考を整理して素早く解決
- テンプレート機能で、簡単に質問をまとめられる
2019/12/01 22:49
ご指摘の通り、carrierwave.rbを修正しました。
しかしながらエラーメッセージは変わりませんでした。
他に確認すべき箇所はあるでしょうか。
2019/12/03 12:34
回答にも書いていますが、
https://github.com/puma/puma/issues/1623
こちらのURLを見る限り、railsではなくて、OSのネットワーク設定に問題がある可能性もあるようです。