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