fly.ioデプロイ時のArgumentErrorを解消したい

実現したいこと

引数のエラーを解消し、デプロイを成功させたい

前提

rails7
fly.io
s3
上記の環境で、crudアプリを作成しています。本番環境での画像データをs3に保存する方針です。

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

Exiting /rails/vendor/bundle/ruby/3.2.0/gems/fog-core-2.3.0/lib/fog/core/service.rb:244:in `validate_options': Missing required arguments: aws_access_key_id, aws_secret_access_key (ArgumentError) raise ArgumentError, "Missing required arguments: #{missing.join(", ")}" ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ from /rails/vendor/bundle/ruby/3.2.0/gems/fog-core-2.3.0/lib/fog/core/service.rb:268:in `handle_settings'

該当のソースコード

evn

1AWS_ACCESS_KEY_ID = 'xxxxxxxxxx' 2AWS_SECRET_ACCESS_KEY = 'xxxxxxxxxx' 3AWS_DEFAULT_REGION='ap-northeast-1' 4RAILS_MASTER_KEY= 'xxxxxxxxxx' 5S3_BUCKET= 'xxxxxxxxxx'

carrierwave.rb

1require 'carrierwave/storage/abstract' 2require 'carrierwave/storage/file' 3require 'carrierwave/storage/fog' 4 5CarrierWave.configure do |config| 6 case Rails.env 7 when 'development', 'test' 8 config.storage = :file 9 config.cache_storage = :file 10 else 11 config.fog_credentials = { 12 provider: 'AWS', 13 aws_access_key_id: ENV['AWS_ACCESS_KEY_ID'], 14 aws_secret_access_key: ENV['AWS_SECRET_ACCESS_KEY'], 15 region: 'ap-northeast-1' 16 } 17 config.fog_provider = 'fog/aws' 18 config.storage :fog 19 config.cache_storage = :fog 20 config.asset_host = "https://s3.ap-northeast-1.amazonaws.com/IAMのユーザー名" 21 config.fog_directory = "IAMのユーザー名" 22 config.fog_public = false 23 end 24end

storage.yml

1test: 2 service: Disk 3 root: <%= Rails.root.join("tmp/storage") %> 4 5local: 6 service: Disk 7 root: <%= Rails.root.join("storage") %> 8 9# Use bin/rails credentials:edit to set the AWS secrets (as aws:access_key_id|secret_access_key) 10amazon: 11 service: S3 12 access_key_id: <%= ENV['AWS_ACCESS_KEY_ID'] %> 13 secret_access_key: <%= ENV['AWS_SECRET_ACCESS_KEY'] %> 14 region: ap-northeast-1 15 bucket: "s3のバケット名"-app-<%= Rails.env %> 16

database.yml

1production: 2 adapter: postgresql 3 encoding: unicode 4 pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %> 5 database: "fly launchで作成したアプリ名"_production 6 username: "fly launchで作成したアプリ名" 7 password: <%= ENV['MYAPP_DATABASE_PASSWORD'] %>

試したこと

コンソール上ではENV["AWS_SECRET_ACCESS_KEY"]を確認すると、evnに保存した情報をとることができます。
このエラーの少し上にWARNING The app is not listening on the expected address and will not be reachable by fly-proxy.という警告も出ています。こちらの方が先に解消すべきエラーでしょうか?
ご教示お願いいたします。

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

コメントを投稿

0 コメント