我是铁杆新手。我想将一个简单的rails应用程序推送到cloudfoundry,我收到一个错误:
====> /logs/stderr.log <====
/var/vcap/data/dea/apps/mytestapp-0
-4a068e3fd2b22422bdd29f3762e9bc9b/app/rubygems/ruby/1.9.1/gems/mongo-
1.6.4/lib/mongo/connection.rb:420:in `connect': Fail:27017 (Mongo::ConnectionFailure)
示例应用程序gemfile:
source 'http://rubygems.org'
gem 'rails', '3.0.5'
gem 'mongo_mapper'
gem 'bson_ext'
mongo.yml:
defaults: &defaults
host: 127.0.0.1
port: 27017
development:
<<: *defaults
database: cloud_foundry_rails_tutorial_development
test:
<<: *defaults
database: cloud_foundry_rails_tutorial_test
# set these environment variables on your prod server
production:
host: <%= JSON.parse( ENV['VCAP_SERVICES'] )['mongodb-2.0'].first['credentials']['hostname']
rescue 'localhost' %>
port: <%= JSON.parse( ENV['VCAP_SERVICES'] )['mongodb-2.0'].first['credentials']['port']
rescue '27017' %>
database: <%= JSON.parse( ENV['VCAP_SERVICES'] )['mongodb-2.0'].first['credentials']['db']
rescue 'cloud_foundry_rails_tutorial' %>
username: <%= JSON.parse( ENV['VCAP_SERVICES'] )['mongodb-2.0'].first['credentials']['username']
rescue '' %>
password: <%= JSON.parse( ENV['VCAP_SERVICES'] )['mongodb-2.0'].first['credentials']['password']
rescue '' %>
我上周没有任何问题就推送到CF但是现在它不起作用了? CF方面有什么变化吗? 感谢
答案 0 :(得分:1)
CloudFoundry.com上周从MongoDB 1.8升级到2.0,这可能会影响你的应用。我将与CF.com工程团队核实并在必要时提交错误。
但是,由于您在mongo.yml
中手动指定了连接信息,您是否禁用了服务的自动配置?为此,请创建文件config/cloudfoundry.yml
并添加:
autoconfig: false
有关Ruby应用程序中服务自动配置的更多信息,请参阅http://blog.cloudfoundry.com/2012/03/12/using-cloud-foundry-services-with-ruby-part-1-auto-reconfiguration/