15

2012 年 6 月 9 日更新:

在 heroku 使用 mongoid 3.0.0.rc 进行设置,请参阅此要点:https ://gist.github.com/2900804

2011 年 1 月 22 日更新:

Uri 现在优先于 mongoid.yml

https://github.com/mongoid/mongoid/issues/issue/266

2010 年 8 月 12 日更新:虽然我在 5 月 6 日从 Jackues Crocker 那里得到了一个接受的答案,但这个问题的某些方面很容易搞砸!它再次发生在我身上,我决定研究 mongoid 源代码。所以,这里是:

目前,主机:端口:名称/数据库:设置优先于uri:设置。因此,由于对localhost:xxxx的请求而不是对flame.local.mongohq.com:xxxx的请求,正在发生非常不具信息性的错误消息

这将打破!

defaults: &defaults
  host: localhost  <- THIS 'OVERWRITES' host in the uri!

production:
  <<: *defaults    <- BE CAREFUL WITH WHAT YOU BRING IN. THE host: FROM DEFAULTS WILL BE THE ONE APPLIED, not your uri host.
  uri: <%= ENV['MONGOHQ_URL'] %>

通过删除主机:默认值和/或删除<<: *defaults来修复它


原始问题:

我在heroku为mongodb添加了mongoHQ插件。它崩溃了:

connect_to_master': failed to connect to any given host:port (Mongo::ConnectionFailure)

正如我所见,在线描述(heroku mongohq)更针对 mongomapper。我正在运行 ruby​​ 1.9.1 和带有mongoid的 rails 3-beta 。

我的感觉是有一些东西ENV['MONGOHQ_URL'],它说 MongoHQ 插件集,但我没有MONGOHQ_URL在我的应用程序中设置任何地方。我想问题出在我的 mongoid.yml 上?

defaults: &defaults
  host: localhost

development:
  <<: *defaults
  database: aliado_development

test:
  <<: *defaults
  database: aliado_test

# set these environment variables on your prod server
production:
  <<: *defaults
  host: <%= ENV['MONGOID_HOST'] %>
  port: <%= ENV['MONGOID_PORT'] %>
  username: <%= ENV['MONGOID_USERNAME'] %>
  password: <%= ENV['MONGOID_PASSWORD'] %>
  database: <%= ENV['MONGOID_DATABASE'] %>

它在本地运行良好,但在 heroku 失败,更多堆栈跟踪:

==> crashlog.log <==
Cannot write to outdated .bundle/environment.rb to update it
/disk1/home/slugs/176479_b14df52_b875/mnt/.bundle/gems/gems/rack-1.1.0/lib/rack.rb:14: warning: already initialized constant VERSION
/disk1/home/slugs/176479_b14df52_b875/mnt/.bundle/gems/gems/mongo-0.20.1/lib/mongo/connection.rb:435:in `connect_to_master': failed to connect to any given host:port (Mongo::ConnectionFailure)
    from /disk1/home/slugs/176479_b14df52_b875/mnt/.bundle/gems/gems/mongo-0.20.1/lib/mongo/connection.rb:112:in `initialize'
    from /disk1/home/slugs/176479_b14df52_b875/mnt/.bundle/gems/gems/mongoid-2.0.0.beta4
/lib/mongoid/railtie.rb:32:in `new'
    from /disk1/home/slugs/176479_b14df52_b875/mnt/.bundle/gems/gems/mongoid-2.0.0.beta4/lib/mongoid/railtie.rb:32:in `block (2 levels) in <class:Railtie>'
    from /disk1/home/slugs/176479_b14df52_b875/mnt/.bundle/gems/gems/mongoid-2.0.0.beta4/lib/mongoid.rb:110:in `configure'
    from /disk1/home/slugs/176479_b14df52_b875/mnt/.bundle/gems/gems/mongoid-2.0.0.beta4/lib/mongoid/railtie.rb:21:in `block in <class:Railtie>'
    from /disk1/home/slugs/176479_b14df52_b875/mnt/.bundle/gems/gems/railties-3.0.0.beta3/lib/rails/initializable.rb:25:in `instance_exec'
.....

这一切都在本地工作,包括测试和应用程序。我没有想法......有什么建议吗?

PS:有高声望的人创建标签'mongohq'?

4

4 回答 4

25

Mongoid (master) 现在在 mongoid.yml 中有一个 URI 选项。所以你可以这样做:

production:
  uri: <%= ENV['MONGOHQ_URL'] %>

要在您的项目中使用 mongoid master,请在您的 Gemfile 中进行设置

gem "mongoid", :git => "git@github.com:mongoid/mongoid.git"

希望很快会发布一个新的 gem 来清理这些东西。

于 2010-05-06T22:18:50.360 回答
11

在我看来,在默认哈希中指定主机会覆盖 uri 中的值。要修复它,只需从默认主机中删除主机,这是我的 config/mongo.yml:

defaults: &defaults
  allow_dynamic_fields: true
  parameterize_keys: true
  persist_in_safe_mode: true
  raise_not_found_error: true
  reconnect_time: 3
  use_object_ids: true

production:
  <<: *defaults
  uri: <%= ENV['MONGOHQ_URL'] %>

这是来自 mongoid 的 config.rb 的片段:

  mongo_uri = settings["uri"].present? ? URI.parse(settings["uri"]) : OpenStruct.new

  name = settings["database"] || mongo_uri.path.to_s.sub("/", "")
  host = settings["host"] || mongo_uri.host || "localhost" # <= look here
  port = settings["port"] || mongo_uri.port || 27017
于 2010-05-31T06:16:04.303 回答
4

我们在我们文档的 heroku 部分有一些 mongoid 文档。它们还没有正式发布,但你已经可以拿到了。不要对样式和内容有太多期望,但它确实有一些您可能会发现对 mongoid 有用的信息。

https://devcenter.heroku.com/articles/mongohq

于 2010-05-07T02:42:18.260 回答
0

请注意,这对我有用,没有任何问题,如http://mongoid.github.com/docs/installation/上所宣传的那样

宝石文件:

gem "rails", '3.0.0.beta3'
gem "mongoid", "2.0.0.beta4"
gem "bson_ext", "0.20.1"

mongoid.yml:

host: xxx.mongohq.com
port: xxx
database: db
username: user
password: xxx
于 2010-05-10T13:17:15.033 回答