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,内存问题得到解决并保持在极限之下。
然后,我尝试升级到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.0负载下的内存消耗量约为386mb,而2.2下的内存消耗现在约为365mb。
这是Ruby(版本2.1.x)及其垃圾收集的已知问题。 在阅读了几个论坛/博客文章后,似乎没有真正的解决方案,但要做以下其中一项:
- 降级到ruby 2.0并等待ruby 2.2发布
- 一旦达到一定数量的内存,使用独角兽工人杀手重启独角兽工人,防止Heroku R14错误
- 一些建议调整你的GC变量(见这里和这里 )
这是关于ruby-lang的相关讨论的链接。
有些人还注意到问题的一个来源可能是NewRelic的gem,所以你可能想要更新/删除它,看看它是否有帮助。
来自upcase.com论坛的一些链接和信息的积分