我有一个火种风格的应用程序,允许用户评价事件.在用户对事件进行评级后,将运行后台resque作业,根据用户的反馈对其他事件进行重新排序.
用一个简单的例子.如果我有10个用户在任何给定时间使用该应用程序,并且我从不想要一份工作等待,那么最佳方法是什么?
我对Dynos,resque pool和redis连接感到困惑.有人能帮我理解差异吗?有没有办法计算这个?
解决方法
不确定你问的是正确的问题.你真正的问题是“我怎样才能获得更好的表现?”不是“有多少dynos?”只是添加动力并不一定会给你更好的表现.更多的dynos会给你更多的记忆……所以如果你的应用程序运行缓慢,因为你的可用内存不足(即你在交换机上运行),那么更多的dynos可能就是答案.如果这些工作每次运行需要10秒,但是…内存可能不是你的实际问题.如果要监视内存使用情况,请查看New Relic等可视化工具.
有很多方法可以解决您的问题.但我会从你写的代码开始.在SO上发布一些代码可能有助于理解为什么该作业需要10秒钟(发布一些代码!). 10秒很长一段时间.因此优化该工作中的查询几乎肯定会有所帮助.
另一块低悬的水果……从resque切换到sidekiq为你的背景工作.真的很容易使用.你将使用更少的内存,并应该看到性能的瞬间提升.