我在heroku上运行了一个eventmachine进程,大约一个小时后,它似乎达到了512MB的内存限制。我开始看到这样的消息:
Error R14 (Memory quota exceeded)
Process running mem=531M(103.8%)我在反应器中运行了很多事件,所以我在想可能是反应器被备份了(我把它想象成一个大队列)?但可能还有其他原因,我对eventmachine还是相当陌生的。
有没有什么好的方法来分析eventmachine并获取它的一些统计数据。作为一个简单的示例,我希望查看队列中安排了多少事件,以查看它是否正在备份并将所有这些事件都保存在内存中。但是如果有人有其他的建议,我将非常感谢。
谢谢!
发布于 2012-09-27 05:13:03
泄漏被证明是在Mongoid的identity_map中(与EventMachine无关)。在事件机进程开始时设置Mongoid.identity_map_enabled = false可解决此问题。
发布于 2012-01-09 18:27:38
我广泛地使用eventmachine,并且从来没有在反应器中遇到过任何内存泄漏,所以你可以打赌ruby代码是这样的,但是如果不了解你的应用程序,就很难给你一个真正的答案。
我现在能想到的唯一的队列是线程池,每次你使用defer方法,这个块要么给一个空闲的线程,要么排队等待一个空闲的线程,我想如果你所有的线程都在阻塞等待某个东西,那么队列可能会增长并使用所有可用的内存。
https://stackoverflow.com/questions/8707915
复制相似问题