Герою-монгог и монгодский монго:: ConnectionFailure
ОБНОВЛЕНИЕ 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-го мая от Jackes Crocker, есть аспекты этой проблемы, которые облегчают беспорядок! Это случилось со мной еще раз, и я решил исследовать исходный код монгоидов. Итак, вот оно:
В настоящее время хост: порт: имя/база данных: настройки ВЗЯТЬ ПРЕЦЕДЕНТНОСТЬ НА УРИ: настройка. Следовательно, ужасно неинформативное сообщение об ошибке происходит из-за запроса на localhost: xxxx и не пламени .local.mongohq.com: хххй
Это сломается!
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'] %>
исправить его либо удалением хоста: по умолчанию, и/или удалением значений < <: * по умолчанию
ОРИГИНАЛ Q:
Я добавил mongoHQ аддон для mongodb в герою. Сбой:
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'] %>
Он работает нормально локально, но не работает в 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'?
Ответы
Ответ 1
Mongoid (master) теперь имеет параметр URI в файле mongoid.yml. Таким образом, вы можете сделать:
production:
uri: <%= ENV['MONGOHQ_URL'] %>
Чтобы использовать mongoid master в своем проекте, установите это в своем Gemfile
gem "mongoid", :git => "[email protected]:mongoid/mongoid.git"
Надеюсь, скоро будет выпущен новый камень, который будет чистить вещи.
Ответ 2
Мне кажется, что указание хоста в хэше по умолчанию переопределяет значение в 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
Ответ 3
У нас есть некоторые mongoid документы в разделе наших героев наших документов. Они еще не выпущены официально, но вы можете получить его к нему уже. Не ожидайте многого в стилях и содержании, но у него есть информация, которую вы можете найти полезной для mongoid.
https://devcenter.heroku.com/articles/mongohq
Ответ 4
Просто заметьте, что это работает для меня без каких-либо проблем, как рекламируется на 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