定时任务调度系统设计


目前定时任务调度系统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


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM