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为你的背景工作.真的很容易使用.你将使用更少的内存,并应该看到性能的瞬间提升.

相关文章

validates:conclusion,:presence=>true,:inclusion=>{...
一、redis集群搭建redis3.0以前,提供了Sentinel工具来监控各...
分享一下我老师大神的人工智能教程。零基础!通俗易懂!风趣...
上一篇博文 ruby传参之引用类型 里边定义了一个方法名 mo...
一编程与编程语言 什么是编程语言? 能够被计算机所识别的表...
Ruby类和对象Ruby是一种完美的面向对象编程语言。面向对象编...