仿照Windows任务计划的数据库设计

一直以为实现一个类型Windows的任务计划的数据库设计(计划调度部分不考虑具体的任务步骤执行),最近认真的看了下每个配置才发现其实也不难,关键是搞清楚不管任务计划怎么个配置(按天,按周,按月),对任务调度进程来说只要知道当前时间点应该执行那些任务就好了,即任务调度进程发现某一任务的“下次执行时间”小于等于当前时间时,则执行之,并且将任务的上次执行时间更新为当前时间,并且根据任务调度配置计算出下次任务的执行时间并更新任务记录。

2011051416034894.jpg

数据库表结构,一次性任务不需要具体的配置信息表,通过[任务调度].[调度类型]来区别具体的调度规则

规则1.一个任务会有多个调度规则,下一执行时间是计算一遍所有调度规则后,获取一个离当前时间最近并且大于当前时间的时间点作为下一执行时间
添加,修改,删除某个调度规则后需要根据当前任务是否运行过来计算出下一运行时间,如果是已经运行过的任务(上一执行时间不为空),那么按规则1,如果是未运行过的任务,那么下一执行时间按所有调度规则配置的第一次执行时间中离当前时间最近并且大于当前时间的时间点作为下一执行时间

2011051416022135.jpg

按策略模式来计算不同调度规则的下一执行时间

2011051416185292.jpg

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值