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

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

在Ubuntu上读取Phusion Passenger内存消耗从1.9.3(系统)增加到2.1.2(RVM)后 ,我尝试将环境变量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,内存问题得到解决并保持在极限之下。

从2.1.5移动到2.0.0 Heroku从2.1.5移动到2.0.0 New Relic

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

<img src="http://sofzh.miximages.com/ruby-on-rails/Ct9Gh.png" alt="使用 RUBY_GC_HEAP_OLDOBJECT_LIMIT_FACTOR 从2.0.0移动到2.1.5到0.9 Heroku”><img src="http://sofzh.miximages.com/ruby-on-rails/pCA5L.png" alt="使用 RUBY_GC_HEAP_OLDOBJECT_LIMIT_FACTOR 从2.0.0移动到2.1.5到0.9 New Relic”>

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

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

内存使用率为2.2

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

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

  • 降级到ruby 2.0并等待ruby 2.2发布
  • 一旦达到一定数量的内存,使用独角兽工人杀手重启独角兽工人,防止Heroku R14错误
  • 一些建议调整你的GC变量(见这里和这里 )

这是关于ruby-lang的相关讨论的链接。

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

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