ruby net/http 打开连接非常慢

问题描述 投票:0回答:4

当我在开发中使用

net/http
时,速度非常慢。我已经安装了
net-http-spy
gem 来获取有关每个请求的一些信息,并且我发现“打开连接”部分花费了最多的时间(超过 10 秒)。此外,它不会保持连接处于活动状态,因此需要根据每个请求重新打开它。

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

有什么方法可以通过设置一些默认值来提高

net/http
库的性能吗?我不需要特定于请求的修复,而是需要能够在全球范围内解决问题的解决方案。我在当前项目中使用
geokit
gem,除了知道它正在使用
net/http
之外,我无法更改它在内部处理请求的方式,并且它在生产(Heroku)上运行良好,但开发速度极其缓慢。

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


这是示例代码:

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 秒..

ruby net-http
4个回答
36
投票

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

这似乎是解析 DNS 路由的某些版本的 libc 的问题。花费几个小时搜索解决方案后,您只需在代码开头添加

require 'resolv-replace'
即可。

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

希望这对将来的人有帮助。


2
投票

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


0
投票

如果上述解决方案不起作用,请检查您的 IP 是否已被 spamhaus.com 列入黑名单。他们会告诉您是否有,如果有,如何解决。


-1
投票

最终解决我问题的是禁用防病毒软件。我有诺顿安全软件

© www.soinside.com 2019 - 2024. All rights reserved.