2012-07-31 2 views
22

MongoID 3와 함께 Rails 3 앱을 성공적으로 배포했습니다. Heroku (MongoHQ 사용) - 그런데 어떤 일이 있었는지 정확히 알 수 없었고 Heroku에서 충돌이 시작되었습니다.Heroku & MongoHQ : ActionView :: Template :: Error (작업 : # <Moped :: Protocol :: Commands :: Authenticate가 "auth fails"오류로 실패했습니다.)

그래서 이것은 내가 오류입니다 :

TLDR이 더 어려워 디버깅 할 수 있습니다 무엇Moped::Errors::AuthenticationFailure (The operation: #<Moped::Protocol::Commands::Authenticate ... failed with error "auth fails")

는 로컬 호스트에서 잘 작동하고 있다는 점이다. 이제는 이것이 무엇인지에 대한 아이디어가 부족합니다.

app[web.1]: >> Thin web server (v1.4.1 codename Chromeo) 
app[web.1]: >> Maximum connections set to 1024 
app[web.1]: >> Listening on 0.0.0.0:58731, CTRL+C to stop 
heroku[web.1]: State changed from starting to up 
app[web.1]: 
app[web.1]: 
app[web.1]: Started GET "/" for 212.86.9.90 at 2012-07-31 08:08:07 +0000 
heroku[router]: GET cool-name-123.herokuapp.com/ dyno=web.1 queue=0 wait=0ms service=171ms status=200 bytes=1286 
heroku[router]: GET cool-name-123.herokuapp.com/assets/application-8e7bfeeffc9291864e5b42d908c2fdda.css dyno=web.1 queue=0 wait=0ms service=11ms status=200 bytes=92524 
heroku[router]: GET cool-name-123.herokuapp.com/assets/application-aa557bde70f1236cdf90c913043c4382.js dyno=web.1 queue=0 wait=0ms service=16ms status=200 bytes=122836 
heroku[router]: GET cool-name-123.herokuapp.com/favicon.ico dyno=web.1 queue=0 wait=0ms service=3ms status=200 bytes=0 
app[web.1]: 
app[web.1]: 
app[web.1]: Started GET "/originals/new" for 212.86.9.90 at 2012-07-31 08:08:11 +0000 
heroku[router]: GET cool-name-123.herokuapp.com/originals/new dyno=web.1 queue=0 wait=0ms service=31ms status=200 bytes=1808 
app[web.1]: 
app[web.1]: 
app[web.1]: Started POST "/originals" for 212.86.9.90 at 2012-07-31 08:08:34 +0000 
app[web.1]: 
app[web.1]: Moped::Errors::AuthenticationFailure (The operation: #<Moped::Protocol::Commands::Authenticate 
app[web.1]: @length=154 
app[web.1]: @request_id=3 
app[web.1]: @response_to=0 
app[web.1]: @op_code=2004 
app[web.1]: @flags=[] 
app[web.1]: @full_collection_name="app123.$cmd" 
app[web.1]: @limit=-1 
app[web.1]: @skip=0 
app[web.1]: @selector={:authenticate=>1, :user=>"heroku", :nonce=>"xyz", :key=>"xyz"} 
heroku[router]: POST cool-name-123.herokuapp.com/originals dyno=web.1 queue=0 wait=0ms service=1486ms status=500 bytes=643 
app[web.1]: @fields=nil> 
app[web.1]: failed with error "auth fails"): 
app[web.1]: app/controllers/originals_controller.rb:19:in `block in create' 
app[web.1]: app/controllers/originals_controller.rb:18:in `create' 
app[web.1]: 
app[web.1]: 
heroku[router]: GET cool-name-123.herokuapp.com/favicon.ico dyno=web.1 queue=0 wait=0ms service=3ms status=304 bytes=0 
app[web.1]: 
app[web.1]: 
app[web.1]: Started GET "/" for 212.86.9.90 at 2012-07-31 08:09:40 +0000 
heroku[router]: GET cool-name-123.herokuapp.com/ dyno=web.1 queue=0 wait=0ms service=11ms status=304 bytes=0 

는 최근 Heroku가 고생했습니다, 그 결과 나는 (새로운 YML 방식 +를 Gemfile에 루비 1.9.3 사용) DB 드라이버의 선택 & 서비스에 대한 올바른 설정을해야한다고 생각합니다 .

내가 heroku config --app app_name를 실행하면 나는

DATABASE_URL  => postgres://rhalppyjrb:[email protected]/rhalppyjrb 
GEM_PATH   => vendor/bundle/ruby/1.9.1 
LANG    => en_US.UTF-8 
MONGOHQ_URL   => mongodb://heroku:[email protected]:27054/app123 
PATH    => bin:vendor/bundle/ruby/1.9.1/bin:/usr/local/bin:/usr/bin:/bin 
RACK_ENV   => production 
RAILS_ENV   => production 
SHARED_DATABASE_URL => postgres://rhalppyjrb:[email protected]/rhalppyjrb 

내 mongoid.yml은 다음과 같습니다 얻을 :

production: 
    sessions: 
    default: 
      uri: <%= ENV['MONGOHQ_URL'] %> 
      options: 
      consistency: :strong 
      skip_version_check: true 
      safe: true 

Gemfile은 다음과 같이이다 :

source 'https://rubygems.org' 

gem 'bundler', '1.2.0.rc' 

ruby '1.9.3' 

gem 'rails', '3.2.6' 
gem 'thin' 
gem 'rmagick', :require => 'RMagick' 
gem "carrierwave-mongoid", :git => "git://github.com/jnicklas/carrierwave-mongoid.git", :branch => "mongoid-3.0", :require => 'carrierwave/mongoid' 

group :assets do 
    gem 'sass-rails', '~> 3.2.3' 
    gem 'coffee-rails', '~> 3.2.1' 
    gem 'uglifier', '>= 1.0.3' 
    gem "therubyracer", :platform => :ruby 
end 

gem 'jquery-rails' 
gem "haml", ">= 3.1.6" 
gem "mongoid", ">= 3.0.3" 
gem "devise", ">= 2.1.2" 
gem "devise_invitable", ">= 1.0.2" 
gem "cancan", ">= 1.6.8" 
gem "rolify", ">= 3.1.0" 
gem "bootstrap-sass", ">= 2.0.4.0" 
gem "simple_form" 

group :development do 
    gem "guard", ">= 0.6.2" 
    gem 'rb-fsevent' 
    gem 'growl' 
    gem "haml-rails", ">= 0.3.4" 
    gem "guard-bundler", ">= 0.1.3" 
    gem "guard-rails", ">= 0.0.3" 
    gem "guard-livereload", ">= 0.3.0" 
    gem "guard-rspec", ">= 0.4.3" 
end 

group :test do 
    gem "database_cleaner", ">= 0.8.0" 
    gem "mongoid-rspec", "1.4.6" 
    gem "email_spec", ">= 1.2.1" 
end 

group :development, :test do 
    gem "factory_girl_rails", ">= 3.5.0" 
    gem "rspec-rails", ">= 2.11.0" 
end 
+0

당신이 MongoHQ_URL 성공적인 연결이 몽고 클라이언트를 사용 있나요? – shingara

+0

정확히 똑같은 문제가있었습니다. 다 괜찮 았어, 나는 db를 실행 : 뭔가를 테스트하기 위해 데이터베이스를 비우려면 reseed, 지금이 오류가 발생. 무엇이 잘못되었는지 알 수 없습니다. localhost에서는 모든 것이 잘 작동하고, 5 분 전까지는 생산 과정에서의 mongo 연결이 문제가되지 않았습니다. – odigity

+0

알아 냈어? – Nerian

답변

20

문제는 사용자의 인증이다 자격 증명이 더 이상 올바르지 않습니다. 특히, 인증하려는 사용자가 더 이상 존재하지 않습니다.

이유는 rake db:reseed을 수행 할 때 DB 수준의 사용자를 포함하여 모든 데이터가 제거되기 때문입니다.

예 :

➜ skadi git:(master) ✗ mongo   
    MongoDB shell version: 2.0.7 
    connecting to: test 
    > use skadi_development 
    switched to db skadi_development 
    > db.system.users.find() 
    > db.addUser("joe", "passwordForJoe") 
    { "n" : 0, "connectionId" : 191, "err" : null, "ok" : 1 } 
    { 
    "user" : "joe", 
    "readOnly" : false, 
    "pwd" : "dac588613249fe92703afb262ec53b82", 
    "_id" : ObjectId("5030d5181cefbd2b04a99e30") 
    } 
    > db.system.users.find() 
    { "_id" : ObjectId("5030d5181cefbd2b04a99e30"), "user" : "joe", "readOnly" : false, "pwd" : "dac588613249fe92703afb262ec53b82" } 
    > exit 
    bye 

    ➜ skadi git:(master) ✗ rake db:reseed 

    ➜ skadi git:(master) ✗ mongo   
    MongoDB shell version: 2.0.7 
    connecting to: test 
    > use skadi_development 
    switched to db skadi_development 
    > db.system.users.find() 
    => Nothing 

은 그래서 당신이 데이터베이스에 연결을 시도, 자격 증명은 더 이상 유효하지 않습니다.

MongoHQ 관리 패널에서 확인할 수 있습니다. 앱을 선택하고 리소스를 클릭하고 MongoHQ를 클릭하면 Heroku로 이동하여 찾을 수 있습니다. 그런 다음 데이터베이스 사용자 탭을 클릭하십시오.

rake db:reseed 예상대로 작동했지만 새 버전의 몽고이드로 변경되었습니다. system. *을 제외한 모든 모음을 제거하려면 rake db:purge을 사용할 수 있습니다.

안정 버전에서는 rake 작업을 아직 사용할 수 없으므로 master 분기를 사용해야 할 수도 있습니다. 또는 코드에 Mongoid.purge!을 사용하면 안정적으로 작동합니다.

상세 사항 : https://github.com/mongoid/mongoid/issues/2275

+0

이것은 작동했습니다. 예상 사용자를 다시 추가해야했습니다. –

+0

도 저에게 효과적입니다. 감사! – okysabeni

+0

완벽하고 매력적인 작품!감사 – RSB

관련 문제