Ale*_*yev 6 ruby cron scheduling resque rufus-scheduler
我需要一个用于大型动态任务集合的调度程序.目前我正在寻找resque-scheduler,rufus-scheduler和clockwork.我将非常感谢您选择使用哪一个(或替代方案).
一些细节:
总而言之,我需要像Ruby项目那样的cron,它可以处理大量动态变化的任务集合.
更新:我花了一天时间尝试调度库,现在我想简要总结一下新获得的经验.
我已经停止了对Clockwork和resque-scheduler库的关注,因为这些是更成熟的项目,有更详细的文档.Resque-scheduler基于rufus-scheduler,而Clockwork受其启发,两者都可以用于我正在寻找的解决方案.
两者都是应该在单独进程中运行的独立服务,可以处理为单个或经常执行而安排的几乎无限量的任务.任务在线程内执行.
发条专业人士:
发条缺点:
我已经为Clockwork实现了一个替代的Manager类(这是控制调度的gem的核心部分),以允许通过ZeroMQ消息进行调度控制.因此,我的项目中的主要服务可以向调度程序发送命令,例如"每天运行"或"取消调度任务#10",并且调度程序立即执行每个请求.
我对resque-scheduler的经验较少,但此时它似乎是一个更好的解决方案.
resque-scheduler专业人士:
Resque.remove_schedule(name)以删除特定任务.resque调度:
仔细观察后可能会出现其他东西,但目前还没有别的东西.
这就是我现在拥有的.顺便说一下,我在GitHub上发布了许多与调度相关的Ruby gem的链接.
某种程度上是纯粹的调度程序。每当由 Crond 支持,所以它是可靠的(但作业将在不同的进程中执行)。Rufus-scheduler 和 Clockwork 很相似,在 Ruby 进程中,调度程序(Clockwork 的灵感来自 rufus-scheduler)。
Resque-scheduler ( https://github.com/resque/resque-scheduler ) 构建在 Resque (任务管理)和 rufus-scheduler (日程管理)之上。
您也应该看看 Sidekiq ( http://sidekiq.org/ )。看看https://www.google.com/?q=sidekiq%20scheduler#q=sidekiq+scheduler
因此,了解 Resque 和 Sidekiq,然后查看适用于它们的调度程序。如果没有什么适合您,请查看调度程序(Whenever、rufus-scheduler、Clockwork,...)本身,也许您可以在它们之上进行构建。
| 归档时间: |
|
| 查看次数: |
1994 次 |
| 最近记录: |