分享

定时任务调度系统设计

 WindySky 2016-05-24

目前定时任务调度系统quartz比较出名,quartz也有集群方案,但把所有任务集中一起就构成了分布式任务系统,耦合性比较高,而且比较重。

我利用zookeeper的特性,设计了一个轻量级的定时任务调度系统。

总体的架构:

总体思路:

1.前端admin负责任务的管理,包含添加任务,删除任务,修改任务到zookeeper(类似数据库)。

2. 后台服务器从zookeeper中获取各自的任务列表。

3. 定时扫描各自的任务列表,任务执行时发送http请求给业务方。

4. 业务方接受到http请求进行业务处理。

具体实现代码参加github(只有雏形,正在完善当中):

https://github.com/nonobank-architect/nono-task-dispatcher

 

用到的组件:

cron-parser:https://github.com/RedHogs/cron-parser/

curator:https://github.com/apache/curator

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多