在我们实际开发项目的过程中,经常需要定时任务来帮我们做一些事情,例如每隔一小时统计新注册的用户数量、每天凌晨一点进行服务器缓存清理、每周五统计购买会员的用户数量等。
springboot在2.0版本之后,提供了非常方便的注解方式来编写定时任务程序,无需添加任何配置文件和依赖关系,快速构建一个springboot项目,添加注解如下:
@springbootapplication@enableschedulingpublic class demoapplication { public static void main(string[] args) { springapplication.run(demoapplication.class, args); }}
@enablescheduling:开启对定时任务的支持
注解方式-单线程
创建schedulertask1类存放与task包下:
@componentpublic class schedulertask1 { @scheduled(cron = "*/6 * * * * ?") private void process(){ system.out.println("schedulertask1 : " + localdatetime.now().tolocaltime() + "\r\n线程 : " + thread.currentthread().getname()); }}
创建schedulertask2类存放与task包下:
@componentpublic class schedulertask2 { @scheduled(fixedrate = 3000) private void process(){ system.out.println("schedulertask2 : " + localdatetime.now().tolocaltime() + "\r\n线程 : " + thread.currentthread().getname()); }}
@scheduled 参数可以接受两种定时的设置,一种是我们常用的cron="*/6 * * * * ?",一种是 fixedrate = 3000,两种都表示每隔x秒打印一下内容。
fixedrate 说明
@scheduled(fixedrate = 3000) :上一次开始执行时间点之后3秒再执行
@scheduled(fixeddelay = 3000) :上一次执行完毕时间点之后3秒再执行
@scheduled(initialdelay=1000, fixedrate=6000) :第一次延迟1秒后执行,之后按
fixedrate 的规则每6秒执行一次
cron表达式参数分别表示:
秒(0~59) 例如0/5表示每5秒
分(0~59)
时(0~23)
日(0~31)的某天,需计算
月(0~11)
周几( 可填1-7 或 sun/mon/tue/wed/thu/fri/sat)
启动项目,执行结果如下:
schedulertask2 : 21:36:47.795008800线程 : scheduling-1schedulertask1 : 21:36:48.014888600线程 : scheduling-1schedulertask2 : 21:36:50.792887400线程 : scheduling-1schedulertask2 : 21:36:53.792697900线程 : scheduling-1schedulertask1 : 21:36:54.002684700线程 : scheduling-1schedulertask2 : 21:36:56.792517700线程 : scheduling-1schedulertask2 : 21:36:59.792606400线程 : scheduling-1schedulertask1 : 21:37:00.002598400线程 : scheduling-1schedulertask2 : 21:37:02.792423300线程 : scheduling-1schedulertask2 : 21:37:05.802238线程 : scheduling-1schedulertask1 : 21:37:06.002225200线程 : scheduling-1
可以看到,当上面两个定时任务同时执行时,用的是同一个线程:scheduling-1,任务的执行时机会受上一个任务执行时间的影响。
注解方式-多线程
新建multithreadscheduletask类存放与task包下:
@component@enableasyncpublic class multithreadscheduletask { @async @scheduled(fixeddelay = 1000) public void first() throws interruptedexception { system.out.println("第一个定时任务开始 : " + localdatetime.now().tolocaltime() + "\r\n线程 : " + thread.currentthread().getname()); thread.sleep(1000 * 10); } @async @scheduled(fixeddelay = 2000) public void second() { system.out.println("第二个定时任务开始 : " + localdatetime.now().tolocaltime() + "\r\n线程 : " + thread.currentthread().getname()); system.out.println(); }}
@enableasync:开启多线程
启动项目,运行结果如下:
第一个定时任务开始 : 21:48:47.121991300线程 : task-1第二个定时任务开始 : 21:48:47.121991300线程 : task-2第一个定时任务开始 : 21:48:48.121930600线程 : task-3第二个定时任务开始 : 21:48:49.114640线程 : task-4第一个定时任务开始 : 21:48:49.114640线程 : task-5第一个定时任务开始 : 21:48:50.119792400线程 : task-6第二个定时任务开始 : 21:48:51.119726900线程 : task-7第一个定时任务开始 : 21:48:51.129727800线程 : task-8第一个定时任务开始 : 21:48:52.130157200线程 : task-2第二个定时任务开始 : 21:48:53.120096500线程 : task-4第一个定时任务开始 : 21:48:53.140095线程 : task-7第一个定时任务开始 : 21:48:54.140429600线程 : task-4第二个定时任务开始 : 21:48:57.130710线程 : task-1
以上就是springboot-定时任务的详细内容。