前记: 之前看xxl-job源码的时候,看xxl的定时任务处理很微妙,不仅仅用了大小线程池,还用了netty手写了一个rpc框架作为模块之间的调用现在看动态的加载定时任务的cron表达式挺好的,
唯一不足的是还可以优化,将第一次查询的数据加入缓存,每次去查的时候需要手动的去控制cron表达式,并将表达式入库,清除缓存并且重新加载。
记住:提高效率就要用缓存,用了自身或者外部缓存就必须考虑缓存的大小(数据量),避免系统数据量过大而导致内存不足。
使用SpringBoot创建定时任务非常简单,目前主要有以下三种创建方式:
一、基于注解(@Scheduled)
二、基于接口(SchedulingConfigurer) 前者相信大家都很熟悉,但是实际使用中我们往往想从数据库中读取指定时间来动态执行定时任务,这时候基于接口的定时任务就派上用场了。
三、基于注解设定多线程定时任务
一、静态:基于注解
基于注解@Scheduled默认为单线程,开启多个任务时,任务的执行时机会受上一个任务执行时间的影响。
1、创建定时器
使用SpringBoot基于注解来创建定时任务非常简单,只需几行代码便可完成:
@Configuration //1.主要用于标记配置类,兼备Component的效果。
@EnableScheduling //2.开启定时任务
public classSaticScheduleTask {//3.添加定时任务
@Scheduled(cron = "0/5 * * * * ?")//或