业务说明:
在工作中,业务上涉及到大量的定时任务,我公司目前采用的是当当的ElasticJob分布式定时任务框架搭建的,由于业务已经成型,在定时任务上改造不太合适,最终决定自己设计一套任务处理框架;用户监控、调整实施运行的每一个任务;
业务场景
我们的业务场景主要是:
一个公司 + 多个账户 ,每个账号下的拥有若干个任务;类似于下面的构图;
设计原因
由ElasticJob控制若干台机器执行任务,由于Elasticjob的局限性,操作不到具体的任务1、任务2等等数据,
如:监控运行时长、强制中断,又或者运行的线程池等等情况,所以针对业务上的任务特别,重新设计了一个 任务处理引擎;
执行流程
1、任何一个任务 最终都会构建成一个 能被线程池执行的 JobExecutor任务;同时由JobManager管理每一个JobExecutor对象;
2、JobExecutor对象 提供:构建时间、执行结束时间、执行状态(可用于中断线程池任务执行),错误异常日志信息 等等,方便JobManager对其监控
下一步内容:
1、增加任务执行监控,结合图标展示每一个job执行的时间,完成情况;
2、增加线程池的监控,JobExecotor是一个可由线程池支持;