业务说明:
在工作中,业务上涉及到大量的定时任务,我公司目前采用的是当当的ElasticJob分布式定时任务框架搭建的,由于业务已经成型,在定时任务上改造不太合适,最终决定自己设计一套任务处理框架;用户监控、调整实施运行的每一个任务;
业务场景
我们的业务场景主要是:
一个公司 + 多个账户 ,每个账号下的拥有若干个任务;类似于下面的构图;

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

执行流程
1、任何一个任务 最终都会构建成一个 能被线程池执行的 JobExecutor任务;同时由JobManager管理每一个JobExecutor对象;
2、JobExecutor对象 提供:构建时间、执行结束时间、执行状态(可用于中断线程池任务执行),错误异常日志信息 等等,方便JobManager对其监控
下一步内容:
1、增加任务执行监控,结合图标展示每一个job执行的时间,完成情况;
2、增加线程池的监控,JobExecotor是一个可由线程池支持;
针对ElasticJob局限性,设计了一套自定义的任务处理框架,支持精细化任务管理和监控,包括任务执行时间、状态及异常日志等。
172万+

被折叠的 条评论
为什么被折叠?



