我的后端学习大纲
XXL-JOB大纲
1、什么是任务调度
- 1.以下面业务场景就需要任务调度来解决问题:
- 某电商平台需要每天上午10点,下午3点,晚上8点发放一批优惠券
- 某银行系统需要在信用卡到期还款日的前三天进行短信提醒
- 某财务系统需要在每天凌晨0:10分结算前一天的财务数据,统计汇总
任务调度是为了自动完成特定任务,在约定的特定时刻去执行任务的过程
2、任务调度实现方式:
2.1.单机任务调度:
- 1.Spring中自带的任务调度:使用Spring中提供的注解
@Scheduled
,也能实现调度的功能,在业务类中方法上贴上这个注解,然后在启动类上贴上@EnableScheduling
注解
@Scheduled(cron = "0/20 * * * * ? ")public void doWork(){//doSomething }
2.2.分布式任务调度:
3、为什么需要分布式调度:
- 1.
高可用
:单机版的定式任务调度只能在一台机器上运行,如果程序或者系统出现异常就会导致功能不可用 - 2.
防止重复执行
: 在单机模式下,定时任务是没什么问题的。但当我们部署了多台服务,同时又每台服务又有定时任务时,若不进行合理的控制在同一时间,只有一个定时任务启动执行,这时,定时执行的结果就可能存在混乱和错误了
- 3.
单机处理极限
:原本1分钟内需要处理1万个订单,但是现在需要1分钟内处理10万个订单;原来一个统计需要1小时,现在业务方需要10分钟就统计出来。你也许会说,你也可以多线程、单机多进程处理。的确,多线程并行处理可以提高单位时间的处理效率,但是单机能力毕竟有限(主要是CPU、内存和磁盘),始终会有单机处理不过来的情况
- 3.