运行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)