我最近在我的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,内存问题得到解决,并且仍处于限制之下。
然后,我尝试升级到Ruby 2.1.5,但将环境变量RUBY_GC_HEAP_OLDOBJECT_LIMIT_FACTOR
设置为0.9。如您所见,内存使用情况略好于原始2.1.5图表,但仍然违反了内存配额。
答案 0 :(得分:12)
所以答案显然是升级到Ruby 2.2版。
令我印象深刻的是,在升级到2.2之后内存使用率实际上已经下降,而升级到2.1则是内存消耗的大幅增加。见下图。
在最左侧,2.0负载下的内存消耗量约为386mb,而2.2时它的消耗量约为365mb。
答案 1 :(得分:4)
这是Ruby(版本2.1.x)及其垃圾收集的已知问题。在阅读了几篇论坛/博客文章之后,似乎没有真正的解决方案,只能做以下其中一项:
这是指向相关discussion on ruby-lang的链接。
有些人还注意到问题的一个来源可能是NewRelic的宝石,所以你可能想要更新/删除它,看它是否有帮助。
来自upcase.com论坛的一些链接和信息的信用