分布式job调度中心 开源项目很多,不需要自己开发。
把当前服务注册到调度中心。 定时器,接口名称,接口参数; 定时任务:定时调用接口,http请求。
调度中心也要进行分布式部署,否则调度中心挂了怎么办?
分布式锁 不可能四台机器全部挂掉。
定时任务
分布式服务时间同步
如果一个分布式系统中,一个服务要调用多个服务,那么那个地方消耗的时间大,必须要服务时钟同步才可,时间同步非常重要。
秒(Seconds) 0~59的整数 , - * / 四个字符
分(Minutes) 0~59的整数 , - * / 四个字符
小时(Hours) 0~23的整数 , - * / 四个字符
日期(DayofMonth) 1~31的整数(但是你需要考虑你月的天数) ,- * ? / L W C 八个字符
月份(Month) 1~12的整数或者 JAN-DEC , - * / 四个字符
星期(DayofWeek) 1~7的整数或者 SUN-SAT (1=SUN) , - * ? / L C # 八个字符
年(可选,留空)(Year) 1970~2099
@Scheduled(cron = "0 0 3 * * ? ")
通配符含义:
*:表示匹配该域的任意值。假如在Minutes域使用*, 即表示每分钟都会触发事件(每月每天都会触发这个事件)。
?:只能用在DayofMonth和DayofWeek两个域。它也匹配域的任意值,但实际不会。因为DayofMonth和DayofWeek会相互影响。例如想在每月的20日触发调度,不管20日到底是星期几,则只能使用如下写法: 13 13 15 20 * ?, 其中最后一位只能用?,而不能使用*,如果使用*表示不管星期几都会触发,实际上并不是这样。
分布式锁 只想一台修改 set成功的机器去跑定时任务,set失败的机器不在执行定时任务。
分布式job调度中心
相当于注册中心,每个需要跑定时任务的微服务都需要自动或者手动注册到上面。
管理后台
执行器管理,任务管理,调度日志,可以查看某个job的执行状况。
多个任务Handler,配置一个端口。一个执行器中可以包含多个Handler,把当前项目注册到分布式job管理中心,成为一个执行器。
1)一个项目中包含多个Handler任务;
一个执行器中可能会配置多个任务。每一个handler都是任务;每个项目都是一个执行器。
分布式调度中心xxl-job——The timestamp difference between admin and executor exceeds the limit.
这是一个时钟同步问题;调度中心和任务执行器需要时间同步,同步时间误差需要在3分钟内,否则抛出异常。
时区问题
任务由调度中心触发,按照在调度中心设置任务的cron表达式触发时,需要注意部署调度中心的机器所在的时区,按照该时区定制化cron表达式。
cron表达式
//整点开始执行,每小时执行一次;
@Scheduled(cron = "0 0 0/1 * * ?")
//零点开始执行,只执行一次;
@Scheduled(cron = "0 0 0 * * ?")
必须使用分布式job框架配置定时任务,便于对定时任务进行管理
1、不能使用setNX处理,要不然每次停止定时job都要重新发布服务,发布的成本太高。
2、医生表的定时任务,一般是慢sql,现在要停掉,只能重新启动。
1、定时job如何进行测试?
2、每个配置都是什么意思?
3、启动运行下,看看代