Config Tire与Bonsai ElasticSearch Heroku附加组件一起使用
所以我有一个rails 3.2 app。 我创建了一个索引。 我按照本指南: https ://gist.github.com/nz/2041121在config/initializers/bonsai.rb
创建一个bonsai.rb文件它看起来像这样:
ENV['ELASTICSEARCH_URL'] = ENV['BONSAI_URL'] # Optional, but recommended: use a single index per application per environment. # Caveat: This convention not be entirely supported throughout Tire's API. app_name = Rails.application.class.parent_name.underscore.dasherize app_env = Rails.env INDEX_NAME = "#{app_name}-#{app_env}"
但是我的工作,这个来自heroku日志的外包:
2013-03-06T17:04:54+00:00 app[web.1]: Processing by SchoolsController#index as HTML 2013-03-06T17:04:54+00:00 app[web.1]: Started GET "/trafikskola?utf8=%E2%9C%93&query=Malm%C3%B6" for 192.165.96.102 at 2013-03-06 17:04:54 +0000 2013-03-06T17:04:54+00:00 app[web.1]: Parameters: {"utf8"=>"✓", "query"=>"Malmö"} 2013-03-06T17:04:58+00:00 heroku[router]: at=info method=GET path=/trafikskola?utf8=%E2%9C%93&query=Malm%C3%B6 host=stormy-escarpment-2346.herokuapp.com fwd="192.165.96.102" dyno=web.1 queue=0 wait=0ms connect=1ms service=3106ms status=500 bytes=643 2013-03-06T17:04:58+00:00 app[web.1]: 2013-03-06T17:04:58+00:00 app[web.1]: app/models/school.rb:19:in `search' 2013-03-06T17:04:58+00:00 app[web.1]: app/controllers/schools_controller.rb:10:in `index' 2013-03-06T17:04:58+00:00 app[web.1]: Completed 500 Internal Server Error in 3073ms 2013-03-06T17:04:58+00:00 app[web.1]: Errno::ECONNREFUSED (Connection refused - connect(2)): 2013-03-06T17:04:58+00:00 app[web.1]: 2013-03-06T17:04:58+00:00 app[web.1]:
我的问题:
- 我应该在bonsai.rb文件中的
ELASTICSEARCH_URL
中添加一些内容吗? 如果是,那又怎样? - 我创建了一个本地索引,这是否意味着什么?
- 或者是别的什么?
config/initializers/bonsai.rb
是正确的,问题是我必须在生产模式下索引它。
所以我这样做了:
heroku rake environment tire:import CLASS=School FORCE=true
它奏效了。