设计一个任务处理引擎(一)

业务说明:

在工作中,业务上涉及到大量的定时任务,我公司目前采用的是当当的ElasticJob分布式定时任务框架搭建的,由于业务已经成型,在定时任务上改造不太合适,最终决定自己设计一套任务处理框架;用户监控、调整实施运行的每一个任务;

业务场景

我们的业务场景主要是:

一个公司 + 多个账户 ,每个账号下的拥有若干个任务;类似于下面的构图;
在这里插入图片描述

设计原因

由ElasticJob控制若干台机器执行任务,由于Elasticjob的局限性,操作不到具体的任务1、任务2等等数据,
如:监控运行时长、强制中断,又或者运行的线程池等等情况,所以针对业务上的任务特别,重新设计了一个 任务处理引擎;

在这里插入图片描述

执行流程

1、任何一个任务 最终都会构建成一个 能被线程池执行的 JobExecutor任务;同时由JobManager管理每一个JobExecutor对象;

2、JobExecutor对象 提供:构建时间、执行结束时间、执行状态(可用于中断线程池任务执行),错误异常日志信息 等等,方便JobManager对其监控

下一步内容:

1、增加任务执行监控,结合图标展示每一个job执行的时间,完成情况;
2、增加线程池的监控,JobExecotor是一个可由线程池支持;

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值