当我在开发中使用net/http时,它非常慢。我安装了net-http-spy gem来获取关于每个请求的一些信息,并且我发现“打开连接”部分花费的时间最多(超过10秒)。此外,它不能保持连接正常,因此需要在每次请求时重新打开它。
opening connection to maps.google.com...
# ~10 seconds
opened有什么办法可以通过设置net/http库的一些默认值来提高它的性能吗?我不想要一个特定于请求的修复,而是一个能够在全球范围内解决这个问题的东西。我在curent项目中使用geokit gem,除了知道它正在使用net/http之外,我无法改变它在内部处理请求的方式,而且它在生产(Heroku)方面工作很好,但开发非常缓慢。
我在上使用了ruby1.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秒钟。
发布于 2012-04-14 12:15:09
这是DNS服务器的问题。切换到google公共DNS (8.8.8.8,8.8.4.4)。谢谢@Ineu。
发布于 2014-12-15 13:37:42
老问题,但我最近也有同样的问题。
它似乎是解决DNS路由的某些版本的libc的问题。在花了几个小时搜索解决方案之后,您只需要在代码的开头添加require 'resolv-replace'即可。
更多信息:https://github.com/ruby/ruby/pull/597#issuecomment-40507119
希望这能对将来的人有所帮助。
发布于 2017-04-09 08:25:06
最终解决问题的是禁用防病毒。我有诺顿保安
https://stackoverflow.com/questions/9939726
复制相似问题