Ruby 的 Net::HTTP 怎么了?

  • Mirko Stocker
  • 张龙

2008 年 11 月 17 日

话题:Ruby语言 & 开发架构

有人可能会问:“Ruby 对 Net:HTTP 的实现出什么问题了”?Adam Nelson 对应用传输大量数据时的表现感到很吃惊。“当数据以 1024 字节块的大小被传输时,我看到了 CPU 的红线”,这是 Adam 在其初次分析时所发现的。实际的问题是“Ruby 针对每个单独的 rbuf_fill 调用都设置一个超时”,Alex Young 说到,“那么在默认情况下,每接收到 1K 数据,就必须产生一个新的线程”。

针对 Ruby 不同的实现和不同的库所进行的一个比较表明 Ruby 1.8.6 对 CPU 的占有率竟然达到了 1.8.7 版的两倍,显然后者使用了更大的缓存(16K)。有趣的是,Ruby 1.9.0 对 CPU 的占有率最低,其实现采用了readpartial:“不对 socket 读取设置超时”,同时“提前为每次读取分配字符串缓存”。紧追其后的是RFuzz,这是一个纯粹的 Ruby 实现,基于 Zed Shaw 所编写的 Mongrel 内核。

该问题早就有人提出来了,2006 年的一个关于 ruby-talk 的邮件列表中就有人在讨论该问题,同时提出了该问题的解决方案。此外,这也证明开源对于我们的帮助和价值是多么大啊。  

查看英文原文:What Is Wrong With Ruby's Net::HTTP?

Ruby语言 & 开发架构