ThreadPoolTaskScheduler
spring 3.0版本后自带的定时任务工具,使用简单方便,不用配置文件,可以动态改变执行状态。也可以使用cron表达式设置定时任务。
被执行的类要实现Runnable接口,override run方法,方法内实现业务逻辑。
(因为想实现的功能是可以动态修改多个定时任务的cron表达式和开关)一开始会进入一个误区,除了启动的时候new了线程池,还会在每次修改配置的时候shutdown线程池,然后new一个新的线程池重新跑。那么就会出现多个线程池都在跑,因为线程池shutdown了,但是线程的任务还在进行中,而我的任务是定时执行的,所以就会一直跑,旧的在跑,新的也在跑。会造成服务ygc频繁,并且ygc的时间也边长。
所以正确的做法应该是:1、线程池仅在服务启动的时候创建。2、每执行一个任务,做一个标记。(一旦服务启动了,后面的操作都应该是针对每一个任务的操作,而不是整个线程池。就算要关掉线程池,也要先销毁线程。)3、stop针对线程future.cancel(true),根据前面的标记,对对应的future处理。4、优雅的关闭线程池
启动的方法调用ThreadPoolTaskScheduler的schedule方法,入参task和cron表达式(我的入参是cron表达式,也可以是task和日期,任务开始的时间)
被执行的类初始化一个map----用来记录task的id和future(每当动态修改定时任务配置的时候,需要stop当前future,然后重启future)线程池是静态的,在容器启动的时候创建就好了,只需要针对每个future处理。
根据前端操作的id来判断停止哪个future
线程池的util类,(可以试用注解,也可以设置为静态全局)线程池只有在服务启动的时候创建,后面都是get操作线程池里的线程。
!!!一定要记得initialize()初始化
最后就是在监听服务启动的时候创建线程池,并且把任务启动。