ruby net / http开放连接很慢

时间:2012-03-30 08:48:24

标签: ruby net-http

当我在开发中使用net/http时,它非常慢。我已经安装了net-http-spy gem以获取有关每个请求的一些信息,并且我发现“打开连接”部分花费的时间最多(超过10秒)。此外,它不会保持连接存活,因此需要在每次请求时重新打开它。

opening connection to maps.google.com...
# ~10 seconds
opened

有什么方法可以通过设置某些默认设置以某种方式提高net/http库的性能?我不想要一个特定于请求的修复程序,但是可以解决全局问题。我在curent项目中使用geokit gem并且我无法在内部更改处理请求的方式,除了知道它正在使用net/http之外,它在生产(Heroku)上工作得很好但是在发展。

我在Mac OS X Lion上使用ruby 1.9.2-p290。使用rbenv安装和管理Ruby。


以下是示例代码:

require 'net/http'
require 'uri'

time = Time.now.to_i
uri = URI.parse("http://maps.google.com/maps/geo?q=Chicago&output=xml&oe=utf-8")

Net::HTTP.get(uri)
puts (Time.now.to_i - time)

Net::HTTP.get(uri)
puts (Time.now.to_i - time)

我放在那里的URL并不重要。每个请求总是需要10秒钟。

3 个答案:

答案 0 :(得分:18)

旧问题,但我最近遇到了同样的问题。

某些版本的libc解决DNS路由似乎存在问题。花了几个小时搜索解决方案后,您只需在代码的开头添加require 'resolv-replace'即可。

更多信息:https://github.com/ruby/ruby/pull/597#issuecomment-40507119

希望这有助于将来的某些人。

答案 1 :(得分:2)

这是DNS服务器的问题。切换到谷歌公共DNS(8.8.8.8,8.8.4.4)。谢谢@Ineu。

答案 2 :(得分:-1)

最终解决问题的方法是禁用防病毒软件。我有Norton Security