微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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.jb51.cc/ruby/270352.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐