20191114 分布式job调度中心

分布式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、启动运行下,看看代

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值