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

转载于:https://www.cnblogs.com/davidwang456/p/5161047.html

定时任务调度系统设计相关推荐

  1. java毕业设计—— 基于java+JSP+SSH的任务调度系统设计与实现(毕业论文+程序源码)——任务调度系统

    基于java+JSP+SSH的任务调度系统设计与实现(毕业论文+程序源码) 大家好,今天给大家介绍基于java+JSP+SSH的任务调度系统设计与实现,文章末尾附有本毕业设计的论文和源码下载地址哦. ...

  2. 分布式定时任务调度系统技术选型

    点击上方"方志朋",选择"设为星标" 回复"666"获取新整理的面试文章 来源:EFbiz blog.csdn.net/guyue35/ar ...

  3. Java定时任务调度工具

    tags: 定时任务调度, title: Java定时任务调度工具 为什么要使用定时任务调度工具? 在最近的开发中,想开发一个"个人备忘录"的功能,实际上就是用户在指定某个时间点后 ...

  4. 一文揭秘定时任务调度框架quartz

    之前写过quartz或者引用过quartz的一些文章,有很多人给我发消息问quartz的相关问题, quartz 报错:java.lang.classNotFoundException quartz源 ...

  5. 分布式定时任务调度系统技术选型--转

    http://www.expectfly.com/2017/08/15/%E5%88%86%E5%B8%83%E5%BC%8F%E5%AE%9A%E6%97%B6%E4%BB%BB%E5%8A%A1% ...

  6. Linux/windows系统定时任务调度总结

    定时任务是办公自动化中比较重要的一环. Linux/windows系统定时任务调度总结 概述 服务启动和关闭 任务调度全局配置 用户配置文件 crontab定时任务格式 crontab定时任务实例 时 ...

  7. python中的轻量级定时任务调度库:schedule

    提到定时任务调度的时候,相信很多人会想到celery,要么就写个脚本塞到crontab中.不过,一个小的定时脚本,要用celery的话太"重"了.所以,我找到了一个轻量级的定时任务 ...

  8. Java 定时任务调度(8)--ElasticJob 入门实战(ElasticJob-Lite使用)

    ElasticJob 是一个分布式调度解决方案,由 2 个相互独立的子项目 ElasticJob-Lite 和 ElasticJob-Cloud 组成.本文主要介绍 ElasticJob-Lite 的 ...

  9. 如何让快递更快?菜鸟自研定时任务调度引擎首次公开

    阿里妹导读:网上购物的普及化带动了物流行业的迅猛发展,同时也带来了极大的压力和严峻的考验,特别是在电商大促的时节.如何有效提高整个物流链路的时效体验,给消费者更好的体验,这是菜鸟物流一直奋斗的目标. ...

最新文章

  1. 烂泥:php5.6源码安装及php-fpm配置与nginx集成
  2. 深入了解Intel保护模式
  3. python如何实现共享报表系统_使用python来实现报表自动化-阿里云开发者社区
  4. 8s存储最佳方案_MaxiDi, 意大利:自动化物流解决方案
  5. java怎么设置背景_如何在Java中设置背景图片?
  6. 在你们看来,信息网络的定级如何才能更好的发展?或者说有什么影响因素使得定级工作不好开展?
  7. 接口测试时,输入所有参数的参数值后,接口返回“参数错误:所有参数都不能为空”
  8. webstorm tsx语法中,使用注释后,发现由红色error
  9. excel表格分割线一分为二_高效秘技!用EXCEL制作导航页和日志表管理日常工作...
  10. paip.手机电话本备份导入到pc管理attilax总结
  11. 公司网站无意使用了”方正字体”,被”索赔
  12. firewalld防火墙IP伪装和端口转发
  13. java 检测表情符号_hutool工具包:判断一个字符串中是否包含emoji表情符号(emoji-java)...
  14. WinRar压缩图片捆绑EXE文件
  15. Python项目分析:预测双色球福利彩票中奖号码
  16. Android实现截屏和截长图功能的几种方法
  17. FHQ Treap 详解
  18. IP地址,子网掩码,默认网关,DNS服务器详解
  19. InDesign插件--常规功能开发--版面调整--js脚本开发--ID插件
  20. 在PowerPoint 2010中向幻灯片添加过渡效果

热门文章

  1. mysql char null_关于mysql设置varchar 字段的默认值''和null的区别,以及varchar和char的区别...
  2. linux下cmake命令行,深入理解CMake(1): CMake命令行参数
  3. 如何快速创建程序组_如何快速开发小程序
  4. DualCircleList
  5. url index.php 怎么去掉,url怎么去掉index.php
  6. mysql get lock_MYSQL-GET_LOCK锁
  7. java range(10)_Java Year range()用法及代码示例
  8. java下载本地目录excel_java写简单Excel 首行是目录 然后前台下载
  9. c++ decltype
  10. c++ 新建一个数组