14

我在将我的 rails 3.0.10 应用程序部署到带有 Passenger、Capistrano、nginx 和 MySQL 的 Ubuntu 10.04 服务器时遇到了很多麻烦(使用 apache2 更麻烦)。将 rake 降级到 0.8.7 后它终于可以工作了,但是现在 Sunspot/Solr 在我的开发环境中不起作用。sunspot_solr 服务器正在运行,我能够获取服务器的 url,并通过浏览器连接到它。url 与 sunspot.yml 中的相同。我不知道我做了什么会导致问题。我之前也遇到过太阳黑子的问题(在我降级 rake 之前)。然后它突然又开始工作了。我不知道为什么...我尝试了两个版本的 Sunspot(1.2.1 和 1.3.0)。两者都在早些时候工作,但现在不再工作了。

这是我收到的错误消息:

SocketError (getaddrinfo: Name or service not known):
app/models/resource.rb:128:in `text_search'
app/controllers/search_controller.rb:21:in `index'

Rendered /usr/lib/ruby/gems/1.8/gems/actionpack-3.0.10/lib/action_dispatch/middleware/templates/rescues/_trace.erb (2.0ms)
Rendered /usr/lib/ruby/gems/1.8/gems/actionpack-3.0.10/lib/action_dispatch/middleware/templates/rescues/_request_and_response.erb (161.6ms)
Rendered /usr/lib/ruby/gems/1.8/gems/actionpack-3.0.10/lib/action_dispatch/middleware/templates/rescues/diagnostics.erb within rescues/layout (168.9ms)

控制器有点乱,所以我只包括相关部分:

@criterion = params[:criterion]
@sort_direction = params[:sort_direction]
if @criterion && @sort_direction
  session["sort_search"] = @criterion + "|" + @sort_direction 
elsif session["sort_search"]
  @criterion = session["sort_search"].split("|")[0]
  @sort_direction = session["sort_search"].split("|")[1]
else
  @criterion = "updated_at"
  @sort_direction = "desc"
 end
@search = Resource.text_search(session[:search_params] || "", current_user, @criterion, @sort_direction) 
@resources = @search.results

自从控制器工作以来,我没有更改控制器中的任何内容。

我的宝石文件:

source 'http://rubygems.org'
gem 'rake'
gem 'rails', '3.0.10'
gem 'jquery-rails', '>= 1.0.12'
gem 'sqlite3'
gem 'ancestry'
gem 'carrierwave'
gem 'sunspot_rails', '>= 1.3' #'~> 1.2.1' #
gem 'authlogic'
gem 'will_paginate'
gem 'declarative_authorization'
group :production do
  gem 'mysql'
end
group :development do
  gem 'sunspot_solr'
end
gem 'capistrano'

我的 rakefile:

require File.expand_path('../config/application', __FILE__)
require 'rake'

Skolearkivet::Application.load_tasks
4

7 回答 7

32

只是一个疯狂的猜测,你有没有机会使用 localhost 作为主机名?尝试将 localhost 更改为 127.0.0.1

于 2012-03-11T11:49:40.253 回答
9

我将此行添加到文件 app/controllers/search_controller.rb 的顶部

require 'resolv-replace'

或者你也可以把它放到 initializers/requires.rb

于 2015-06-12T23:27:31.573 回答
2

我在 OSX 上的 rails 和 logstasher 也遇到了同样的问题,直到我读到这篇文章才知道发生了什么。以为我会添加这个,以便其他任何与logstasher有相同问题的人都可以找到一些东西......

`=> Booting Unicorn
=> Rails 4.2.5 application starting in development on http://0.0.0.0:3000
=> Run rails server -h for more startup options
=> Ctrl-C to shutdown server
Exiting
/Users/xx/Projects/xx/config/environments/development.rb:80:in 'getaddress': getaddrinfo: nodename nor servname provided, or not known (SocketError)`

修复是将我的机器主机名添加到 /etc/hosts 下的列表中 127.0.0.1

于 2016-07-19T19:23:19.443 回答
1

我有一个类似的问题,我通过编辑 /etc/resolv.conf 解决了这个问题

nameserver 10.0.x.x
search example.com

#nameserver 10.0.x.x
nameserver 8.8.8.8
#search example.com
于 2015-01-15T00:06:51.060 回答
1

对我来说,删除我的 resolv.conf 中的搜索行就足够了。我的公司自动插入了它自己的域,并且我的主机名不是我的主机文件中的 FQDN。这显然是一个测试环境。

于 2017-09-29T10:19:08.533 回答
1

可能是您的第三方服务 URL 之一不正确。例如,我们有错误的 SMTP 邮件地址。应用程序中的一个异常导致它通过电子邮件将错误发​​送给管理员,并因错误而失败。以下是您如何知道地址错误的方法:

irb(main):009:0> Socket.gethostbyname("example.net")
SocketError: getaddrinfo: Name or service not known
于 2018-04-30T22:00:42.260 回答
1

我添加了这一行

需要“解决替换”

到我的错误来自的控制器文件,它对我有用。希望它也适合你!

于 2018-08-08T07:40:02.370 回答