繁体   English   中英

在Heroku上运行delayed_job工作者?

[英]Running delayed_job worker on Heroku?

所以现在我有一个delayed_job的实现,它完全适用于我的本地开发环境。 为了在我的机器上启动工作人员,我只是运行rake jobs:work ,它完美地工作。

为了让delayed_job在heroku上工作,我一直在使用几乎相同的命令: heroku run rake jobs:work 这个解决方案可以工作,我不需要为Heroku支付任何工作成本,但是我必须保持命令提示窗口打开,否则我关闭时就会停止delayed_job工作。 是否有命令永久保持这个delayed_job工作程序即使在我关闭命令窗口时也能正常工作? 或者还有另一种更好的方法吗?

我推荐无用的宝石在heroku上运行延迟的工作。 我现在使用它 - 它对我来说非常有效,零麻烦且零成本。

我还使用了hirefireapp ,它可以对扩展工作者进行更精细的控制。 这需要花费,但成本低于单个heroku工作者(超过一个月)。 我现在不使用它,但已经使用过它,它运行得很好。

worker: rake jobs:work

到您的Procfile

编辑:

即使你从你的控制台运行它你'买'工人dyno但是Heroku每秒钟都会被打包。 所以你不付钱,因为你有750小时的免费,而最坏的情况下有一个月有744小时,所以你有额外的dynos,调度任务等6小时免费。

我还没有尝试过,但你可能会觉得nohup很有用。 即使您已关闭终端窗口,它也允许您的进程运行。 链接: http//linux.101hacks.com/unix/nohup-command/

使用heroku控制台让工作人员进入工作岗位只会为工作创建一个临时的dyno。 要保持作业在没有cli的情况下运行,您需要将命令放入Procfile中,如@Lucaksz建议的那样。

部署之后,你还需要扩展dyno形式,因为heroku需要知道应该将多少dyno放到进程类型上,如下所示: heroku ps:scale worker = 1

更多细节可以在这里阅读https://devcenter.heroku.com/articles/scaling

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM