0

运行heroku run rake db:migrate并得到错误:

Running `rake db:migrate` attached to terminal... up, run.9259
DEPRECATION WARNING: railtie_name is deprecated and has no effect. (called from <top (required)> at /app/config/application.rb:10)
WARNING: Global access to Rake DSL methods is deprecated.  Please include
    ...  Rake::DSL into classes and modules which use the Rake DSL methods.
WARNING: DSL method Quora::Application#task called at /app/vendor/bundle/ruby/1.9.1/gems/railties-3.0.5/lib/rails/application.rb:214:in `initialize_tasks'
rake aborted!
Database should be a Mongo::DB, not NilClass.

本地一切运作良好。我有一个mongoid.yml包含 mongo 配置的文件,并使用 mongohq 创建了一个 mongo db:

defaults: &defaults
  host: '127.0.0.1'
  autocreate_indexes: false
  allow_dynamic_fields: true
  include_root_in_json: false
  parameterize_keys: true
  persist_in_safe_mode: false
  raise_not_found_error: true
  reconnect_time: 3

development:
  <<: *defaults
  database: mydb_development

development_mongohq:
  <<: *defaults
  #use demo mongohq database for fast run
  uri: mongodb://user:pass@linus.mongohq.com:10016/app9861715

test:
  <<: *defaults
  database: quora_test

# set these environment variables on your prod server
production:
  <<: *defaults
  host: '127.0.0.1'
  database: mydb

我曾尝试寻找解决方案或任何有关如何解决但没有成功的方向。我究竟做错了什么?

编辑:我添加include Rake::DSL到我的 Rakefile 中,现在最初的警告消失了,但我仍然得到:

heroku run rake db:migrate
Running `rake db:migrate` attached to terminal... up, run.4751
DEPRECATION WARNING: railtie_name is deprecated and has no effect. (called from <top (required)> at /app/config/application.rb:11)
rake aborted!
Database should be a Mongo::DB, not NilClass.

Tasks: TOP => db:migrate => environment
(See full trace by running task with --trace)
4

1 回答 1

0

我认为你错过了:

adapter: mongodb

这是我对 postgres database.yml 的设置:

development: 
  adapter: postgresql
  encoding: unicode
  database: db
  pool: 50
  username: user
  password: pwd
  host: localhost

您可能还想查看这篇文章:

https://stackoverflow.com/a/6757749/169277

于 2012-12-08T03:24:57.233 回答