Ruby 2.1与Ruby 2.0或1.9相比内存使用量增加

时间:2014-11-24 10:25:51

标签: ruby-on-rails ruby memory heroku ruby-2.1

我最近在我的Heroku Web应用程序中部署了从2.0升级到2.1.5的Ruby,我现在一直在调整内存配额错误,而2.0和1.9这种情况从未发生过。对于普通的Heroku Dyno,限制为512MB,我使用Unicorn运行2个进程,并且在两个dynos中运行Sidekiq的一个线程。

在阅读Phusion Passenger memory consumption increase from 1.9.3 (system) to 2.1.2 (RVM) on Ubuntu之后,我尝试将环境变量RUBY_GC_HEAP_OLDOBJECT_LIMIT_FACTOR设置为0.9以禁用分代垃圾收集器,它确实在一定程度上改善了内存消耗,但仍然让我无法接近消耗的2.0或1.9。由于现在的内存是我最关心的问题,我想看看我是否可以使用ruby 2.1.x修复此问题,而不是恢复到2.0。

以下是一些展示问题的图表:

在下午2点之前,我将Ruby 2.0.0-p598降级为Ruby 2.1.5,内存问题得到解决,并且仍处于限制之下。

moving from 2.1.5 to 2.0.0 Heroku moving from 2.1.5 to 2.0.0 New Relic

然后,我尝试升级到Ruby 2.1.5,但将环境变量RUBY_GC_HEAP_OLDOBJECT_LIMIT_FACTOR设置为0.9。如您所见,内存使用情况略好于原始2.1.5图表,但仍然违反了内存配额。

moving from 2.0.0 to 2.1.5 with <code>RUBY_GC_HEAP_OLDOBJECT_LIMIT_FACTOR</code> to 0.9 Heroku moving from 2.0.0 to 2.1.5 with <code>RUBY_GC_HEAP_OLDOBJECT_LIMIT_FACTOR</code> to 0.9 New Relic

2 个答案:

答案 0 :(得分:12)

所以答案显然是升级到Ruby 2.2版。

令我印象深刻的是,在升级到2.2之后内存使用率实际上已经下降,而升级到2.1则是内存消耗的大幅增加。见下图。

Memory usage with 2.2

在最左侧,2.0负载下的内存消耗量约为386mb,而2.2时它的消耗量约为365mb。

答案 1 :(得分:4)

这是Ruby(版本2.1.x)及其垃圾收集的已知问题。在阅读了几篇论坛/博客文章之后,似乎没有真正的解决方案,只能做以下其中一项:

  • 降级到ruby 2.0并等待ruby 2.2发布
  • 使用unicorn worker killer一旦达到一定数量的内存就重启unicorn worker,防止Heroku R14错误
  • 有人建议调整您的GC变量(请参阅herehere

这是指向相关discussion on ruby-lang的链接。

有些人还注意到问题的一个来源可能是NewRelic的宝石,所以你可能想要更新/删除它,看它是否有帮助。

来自upcase.com论坛的一些链接和信息的信用