InfoQ

InfoQ

新闻

我的书签

登录注册 以永久保存书签。

该内容已经被标记书签!

标记书签错误,请重试!

1.8.x的新修复解决了内存泄漏问题并改进了性能

作者 Werner Schuster 译者 张龙 发布于 2009年1月8日

领域
架构 & 设计,
语言 & 开发
主题
运行时 ,
Ruby on Rails ,
性能和可伸缩性 ,
Ruby
标签
Rails ,
垃圾回收

就性能而言,目前Ruby 1.9.1和JRuby领导着Ruby的实现。然而由于种种原因,转到这两个实现中的任何一个都不是那么容易的事情,因为Ruby 1.9.x在有些地方与1.8.7不兼容,同时JRuby仍旧缺乏一些使用本地扩展的Ruby库。由于这个原因,MRI 1.8.x还会继续存在一段时间,那么我们可能对其性能的改进产生兴趣。

目前Brent Roman在一定程度上改进了Ruby 1.8.x MRI的性能。他正不断尝试着修复Ruby中的内存泄漏问题

基本的技术就是对Kurt Stephens所建议的一个问题的精化。它不仅消除了这行代码的泄漏问题:
loop {@x=callcc{|c|c}}
还消除了我们多线程机器人技术应用中的泄漏问题。过去我们所使用的Ruby进程在运行一天后常常达到20+MB,而现在已经降到了10MB以下。

正如其所示,泄漏是由GCC的优化所导致的:它与Ruby的旧式GC的交互很差劲

垃圾收集器的内存泄漏问题并不是它本身的错误。问题在于“C”机器栈(machine stack)中充满了对象引用。其主要原因是由于gcc编译器创建了过多大的stack frame而又没有对其初始化。用在Ruby解释器的核心递归表达式程序中的某些“C”构造会生成特别大而又稀疏的stack frame。函数rb_eval()就是最差劲的一个,它会为每次调用都创建KB大小的stack frame,而其又会调用自身几百次。这导致栈的容量急剧膨胀,经常充满了不再使用而又无法移除的对象引用。

Brent提供了一些修复(针对Ruby 1.8.7-patlevel72),目的在于解决这些问题。

当运行在真实世界的Rails应用上时,测试报告表明该修复对速度的提升效果很明显。同时也报告了一些问题,让我们对其拭目以待吧。

这些修复是开源(Ruby)社区对MRI改进的又一个证明。Mod_rails (或REE)已经是一个佐证了,它使得MRI的垃圾收集器更加友好(参见相关新闻以了解更多)。

MRI的性能在很大程度上取决于它的编译方式

今年你还打算继续使用Ruby 1.8.x么?如果是的话,理由呢?

查看英文原文:New Patches for 1.8.x Fix Memory Leaks And Improve Performance

译者 张龙 热衷于编程,乐于分享,对新技术有强烈的探索欲,对Java轻量级框架有一定研究。

这篇文章写的错误百出 发表人 Fan Robbin 发表于
Re: 这篇文章写的错误百出 发表人 Guo Xiaogang 发表于
Re: 这篇文章写的错误百出 发表人 Guo Xiaogang 发表于
  1. 返回顶部

    这篇文章写的错误百出

    发表人 Fan Robbin

    内存泄漏问题根本就不是GC优化导致的,而是幽灵指针引起的。

    Brent Roman的MBARI patch也并非只能用在1.8.7上面,一旦该补丁被合并到trunk以后,他会后续提交1.9.1的patch。

    这篇文章错误太多了,简直就是误导。看看我写的介绍吧:

    ruby内存泄漏的罪魁祸首 - 幽灵指针

    解决ruby内存泄漏的超级大补丁发布啦

  2. 返回顶部

    Re: 这篇文章写的错误百出

    发表人 Guo Xiaogang

    注意没有人说是“GC优化导致的”,文中说的是“GCC优化”。可能大写有误导吧。

    所谓“gcc optimizations”我想是指


    [...]gcc compilers create overly large stack frames and do not initialize many values in them[...]

    你所说的“幽灵指针”不就是来自这些没初始化的stack frames。这种做法最后怎么变成内存泄漏,你已经解释得很清楚。Brent的补丁说明里面也介绍得很清楚。

  3. 返回顶部

    Re: 这篇文章写的错误百出

    发表人 Guo Xiaogang

    差点忘了谢谢Robbin Fan。

    多谢补充这两篇出色的介绍和1.9.1补丁的信息。

深度内容

大规模视频网站的计费与流量管理

本次分享将会就大规模视频网站的计费与流量管理这个话题,从操作层面细细进行讲解和分析,为系统工程师们揭示平日里我们没有关心的另一些内容。同时也希望本次分享能揭示行业中的一些“潜规则”,让互联网行业的流量与带宽管理更为开放与简洁。
本次演讲视频录制于QCon杭州2011

专访Jeffrey Richter:Windows 8是微软的重中之重

Jeffrey Richter以其多本Windows核心技术的经典著作而闻名,同时,他深入掌握微软的.NET等一系列核心技术,2012年1月,Jeffrey Richter在北京接受了InfoQ中文站的专访,谈到Windows 8和WinRT编程,并就异步编程、Windows编程中的可扩展性、性能和安全性方面给出自己的建议。

应用云平台的可用性——从新浪SAE看云平台设计

云计算平台的可用性,相比传统互联网服务而言,更加复杂和困难,也更具有挑战性。本文借助新浪SAE云平台为读者讲述了云平台可用性的定义、如何打造高可用的平台,以及对云计算的用户提出了建议。

JVM定制改进 @ 淘宝

淘宝高度重视Java平台的健康发展,组建了一个团队专注于Java平台的底层部分的性能、功能与稳定性改进;工作主要基于OpenJDK中的HotSpot VM开展,其中一些通用的功能随后也会逐渐反馈给OpenJDK社区。希望能与使用Java平台开发应用的大家交流经验。
本次演讲视频录制于QCon杭州2011

"伤得起"的云计算应用——对云端应用之架构的思考

2011年4月21日至22日是值得云计算从业者纪念的日子。Amazon的IaaS服务出现故障,导致许多商业网站的服务中断,影响非常严重。作为云计算用户,我们需要思考的是,如何保证即便在云服务不可用的情况,我们的应用架构仍然能够屹立不倒?本文正是站在云计算用户的角度试图探讨这一问题。

让交付的速度跟上思考的速度

12人的技术团队,4组刀片服务器,每月20亿的访问量,每日1次准时部署,99.9%的可用性。这可能吗?当然。想知道如何做的吗?百姓网将与您分享他们在DevOps实践过程中的经验和技巧。
本次演讲视频录制于QCon杭州2011

架构之路——穿行在产品和业务之间

篱笆作为一家起源于社区的电子商务公司,反映到技术层面就是同时要面对产品和业务,以及经营战略的变化调整。如何在产品和业务的夹缝之间完成技术架构的抽象与平衡,寻找更有效的价值定位,这当中有些经验教训和个人感悟愿与众人分享。
本次演讲视频录制于QCon杭州2011

特性注入:成功三部曲

本文将对特性注入以及相关方法做一个扫盲性的介绍。我们会解释这个框架的关键要素,并附上实例来证实它们。为了让文章保持相对较短,我们不会深入到某个工具或方法中,而是会给出一些参考资料,以便大家做进一步的研究。