gpt4 book ai didi

ruby-on-rails - Redis 与 postgres 冲突 - 错误 'database configuration does not specify adapter'

转载 作者:IT王子 更新时间:2023-10-29 06:07:56 25 4
gpt4 key购买 nike

问题:

我使用 postgresql(pg gem、redis gem)将 Redis 添加到我的 Rails 应用程序,但现在无法部署到我的暂存环境。 Cap 失败并显示此错误消息,在 db:schema:dump 之后:database configuration does not specify an adapter

环境通过了所有规范并在本地运行得很好。

如果我删除了 redis gem、redis.yml 和 redis.rb,应用程序部署正常,没有错误。

故障排除:

以下是我采取的故障排除步骤:

  • 确认我的 staging.yml 没有隐藏字符(通过使用之前提交的相同文件证明了这一点)
  • 添加redis前备份commit,完美部署
  • 删除了 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

文件:

这是我的 redis.yml,存储在 config\:

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

这是我的 redis.rb,它声明了要在应用程序中使用的 redis 实例:

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 的相关部分:

gem 'rails', '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'

最佳答案

从评论中复制答案以便从“未回答”过滤器中删除此问题:

Figured out that my $redis.flushdb command was the cause of the problem. After removing that, entirely, I can deploy now. I had that for clearing the redis store during rspec, so now I need to get that added back in, somehow. Oh well.

~ 根据 user1775141 回答

关于ruby-on-rails - Redis 与 postgres 冲突 - 错误 'database configuration does not specify adapter',我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16174100/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com