ruby-on-rails – Rails&Heroku:我需要多少工人/ dynos

前端之家收集整理的这篇文章主要介绍了ruby-on-rails – Rails&Heroku:我需要多少工人/ dynos前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个火种风格的应用程序,允许用户评价事件.在用户对事件进行评级后,将运行后台resque作业,根据用户的反馈对其他事件进行重新排序.

后台作业大约需要10秒钟,每个用户每分钟运行大约20次.

用一个简单的例子.如果我有10个用户在任何给定时间使用该应用程序,并且我从不想要一份工作等待,那么最佳方法是什么?

我对Dynos,resque pool和redis连接感到困惑.有人能帮我理解差异吗?有没有办法计算这个?

解决方法

不确定你问的是正确的问题.你真正的问题是“我怎样才能获得更好的表现?”不是“有多少dynos?”只是添加动力并不一定会给你更好的表现.更多的dynos会给你更多的记忆……所以如果你的应用程序运行缓慢,因为你的可用内存不足(即你在交换机上运行),那么更多的dynos可能就是答案.如果这些工作每次运行需要10秒,但是…内存可能不是你的实际问题.如果要监视内存使用情况,请查看New Relic等可视化工具.

有很多方法可以解决您的问题.但我会从你写的代码开始.在SO上发布一些代码可能有助于理解为什么该作业需要10秒钟(发布一些代码!). 10秒很长一段时间.因此优化该工作中的查询几乎肯定会有所帮助.

另一块低悬的水果……从resque切换到sidekiq为你的背景工作.真的很容易使用.你将使用更少的内存,并应该看到性能的瞬间提升.

原文链接:https://www.f2er.com/ruby/270352.html

猜你在找的Ruby相关文章