嗨
,我将建立一个 rails 网站,在一些初始用户输入之后,完成一些繁重的计算(通过对 ruby 的 c 扩展,将使用多线程)。由于这些计算将消耗几乎所有的 cpu 时间(也包括内存),因此一次运行的计算不应超过一个。我也不能使用(异步)后台作业(例如延迟作业),因为 rails 必须显示该计算的结果,并且该站点应该在没有 javascript 的情况下工作。
所以我想我需要一个单独的进程,其中所有 rails 实例都必须将其计算请求排队并等待答案(如果队列已满,可能会出现错误消息),这是一种同步作业管理器。
有谁知道是否有具有这种功能的 gem/插件?(nanite对我来说似乎很酷,但似乎只是异步的,所以 rails 实例不知道计算何时完成。对吗?)
另一个想法是使用分布式 ruby (drb) 编写我自己的,但为什么要发明如果它已经存在,再次轮子?
任何帮助,将不胜感激!
编辑:由于 zaius 的提示,我认为我将能够异步执行此操作,所以我将尝试resque。