2

問題:

postgresql (pg gem、redis gem) を使用して Rails アプリに Redis を追加しましたが、ステージング環境にデプロイできません。db:schema:dump の後、Cap が次のエラー メッセージで失敗します。database configuration does not specify an adapter

環境はすべての仕様に合格し、ローカルで問題なく実行されます。

redis gem、redis.yml、および redis.rb を削除すると、アプリはエラーなしで正常にデプロイされます。

トラブルシューティング:

私が行ったトラブルシューティング手順は次のとおりです。

  • staging.yml に隠し文字がないことを確認しました (以前のコミットの同じファイルを使用して証明されました)。
  • redisを追加する前にコミットするためにバックアップし、完全にデプロイしました
  • Redmon が問題の原因である疑いがあるため、Redmon を削除しました
  • pg を 0.15.1 にアップグレードし、redis を 3.0.4 にアップグレードしました (同じエラー)
  • redis-server が実際にステージング環境で実行されていることを確認

私はこれについての言及をどこでも探しましたが、「あなたのdatabase.ymlファイルには隠し文字があります」ということしか思いつきませんでした。

私はこの問題に 9 時間も取り組んでいるので、どんな助けでも大歓迎です。

これは私の最初の StackOverflow の質問です。重要な情報が不足している場合はお知らせください。

バックグラウンド:

実行時に実際に発生するエラーは次のcap staging deployとおりです。

* executing "cd /var/www/apps/MY_APP_NAME/current && RAILS_ENV=staging bundle exec rake db:migrate"
servers: ["XXX.XXX.XXXX"]
[XXX.XXX.XXXX] executing command
[XXX.XXX.XXXX] /bin/bash -c 'cd /var/www/apps/MY_APP_NAME/current && RAILS_ENV=staging bundle exec rake db:migrate'
** [out :: XXX.XXX.XXXX] Cannot load Rspec tasks.
** [out :: XXX.XXX.XXXX] rake aborted!
** [out :: XXX.XXX.XXXX] database configuration does not specify adapter
** [out :: XXX.XXX.XXXX] 
** [out :: XXX.XXX.XXXX] Tasks: TOP => db:schema:dump
** [out :: XXX.XXX.XXXX] 
** [out :: XXX.XXX.XXXX] (See full trace by running task with --trace)
** [out :: XXX.XXX.XXXX] 
command finished in 18753ms

ファイル:

config\ の下に保存されている私の redis.yml は次のとおりです。

default:
  host: localhost
  port: 6379
development:
  db: 0
test:
  db: 1
staging:
  db: 2
production:
  db: 3

アプリで使用するための redis インスタンスを宣言する redis.rb は次のとおりです。

REDIS_CONFIG = YAML.load( File.open( Rails.root.join("config/redis.yml") ) ).symbolize_keys
dflt = REDIS_CONFIG[:default].symbolize_keys
cnfg = dflt.merge(REDIS_CONFIG[Rails.env.to_sym].symbolize_keys) if REDIS_CONFIG[Rails.env.to_sym]

$redis = Redis.new(cnfg)

# To clear out the db before each test
$redis.flushdb if Rails.env = "test"

ここに私のstaging.ymlがあります:

staging: &staging
  adapter: postgresql
  encoding: unicode
  database: MY_APP_NAME_staging
  pool: 5
  username: postgres
  min_messages: warning

私のGemfileの関連部分は次のとおりです。

宝石「レール」、「3.2.2」

gem 'pg', '0.13.2'
gem 'redis', '3.0.4'
gem 'activeadmin', '0.4.4'
gem 'acts-as-taggable-on', '2.2.2'
gem 'backup', '3.0.20', :require => false
gem 'backup-task', '0.2.0'
gem 'chargify_api_ares', '0.5.2'
gem 'devise', '2.0'
gem 'dynamic_form', '1.0.0'
gem 'escape_utils', '0.1.9'
gem 'factory_girl_rails', '1.0'
gem 'fog','0.11.0', :require => false
gem 'foreigner', '0.9.1'
gem 'formtastic', '2.1.1'
gem 'haml', '3.1.4'
gem 'hoptoad_notifier', '2.4.0'
gem 'inherited_resources', '1.3.1'
gem 'jquery-rails', '1.0.14'
gem 'less-rails-bootstrap', '2.0.10'
gem 'log_buddy', '0.6.0'
gem 'meta_search', '1.1.3'
gem 'mustache', '0.99.4'
gem 'nested_form', :git => "https://github.com/ryanb/nested_form.git", :ref => "486e0f0e93f3ca455d5d"
gem 'nokogiri', "~> 1.5.0"
gem 'paperclip', '3.1.2'
gem 'rake', "0.9.2", :require => false
gem 'rdiscount', '1.6.5'
gem 'tinymce-rails', '3.5.4.1'
gem 'whenever', '0.6.8', :require => false
gem 'amoeba', '1.2.1'
4

1 に答える 1