Heroku Mongohq и Mongoid Mongo :: ConnectionFailure - PullRequest
15 голосов
/ 07 мая 2010

ОБНОВЛЕНИЕ 9 июня 2012 г .:

Настройка с mongoid 3.0.0.rc на heroku, см. Эту суть: https://gist.github.com/2900804

ОБНОВЛЕНИЕ 22 января 2011 г .:

Ури теперь имеет приоритет в mongoid.yml

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

ОБНОВЛЕНИЕ 12 августа 2010: Хотя я получил приемлемый ответ 6 мая от Жака Крокера, есть аспекты этой проблемы, которые позволяют легко запутаться! Это случилось со мной еще раз, и я решил исследовать исходный код 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'] %>

исправить это, либо удалив хост : по умолчанию, и / или удалив <<: * по умолчанию </em>


ОРИГИНАЛ Q:

Я добавил mongoHQ аддон для mongodb на heroku. Вылетает с:

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

Описания онлайн ( heroku mongohq ), на мой взгляд, больше направлены на mongomapper. Я использую ruby ​​1.9.1 и rails 3-beta с mongoid .

Мне кажется, что с 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'] %>

Локально работает, но на героку не работает, больше трассировки стека:

==> 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 ]

25 голосов
/ 07 мая 2010

Mongoid (master) теперь имеет параметр URI в mongoid.yml. Так что вы могли бы сделать:

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

Чтобы использовать Mongoid Master в вашем проекте, установите это в своем Gemfile

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

Надеюсь, скоро выйдет новый драгоценный камень, который очистит вещи.

11 голосов
/ 31 мая 2010

Мне кажется, что указание хоста в хеше по умолчанию переопределяет значение в 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'] %>

Вот фрагмент из файла config.rb mongoid:

  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
4 голосов
/ 07 мая 2010

У нас есть несколько монгоидных документов в разделе наших героев. Они еще не были официально выпущены, но вы уже можете получить его. Пока не ожидайте многого от стиля и контента, но в нем есть информация, которая может оказаться полезной для mongoid.

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

0 голосов
/ 10 мая 2010

Просто обратите внимание, что это работает для меня без каких-либо проблем, как указано на http://mongoid.github.com/docs/installation/

Gemfile:

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
...