Springtask中怎么使用定时任务-成都快上网建站

Springtask中怎么使用定时任务

Spring task中怎么使用定时任务,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

成都创新互联凭借专业的设计团队扎实的技术支持、优质高效的服务意识和丰厚的资源优势,提供专业的网站策划、成都网站制作、成都做网站、网站优化、软件开发、网站改版等服务,在成都十多年的网站建设设计经验,为成都超过千家中小型企业策划设计了网站。

使用

现在开发都是基于 springboot,而在 springboot 中配置 spring task 尤为简单。

步骤如下:

  1. 准备一个 springboot 工程

  2. 在启动类上添加 @EnableScheduling 注解

    @SpringBootApplication
    @EnableScheduling
    public class DemoApplication {
    }

  3. 在定时执行的方法上添加 @Scheduled(fixedDelay = 3 * 1000) 注解

    @Scheduled(fixedDelay = 3 *1 000)
    public void p1(){
    	System.out.println(Thread.currentThread().getName() + "  p1");
    }

注意: 第三步注解的属性会在后面细讲

@Scheduled 注解

在说注解属性之前, 需要了解下 Spring 定时器的三种工作模式。

1. fixedDelay

当上一次的任务执行完成之后, 再等 3 秒钟, 执行下一次任务。

示意图如下:

Spring task中怎么使用定时任务

配置如下:

@Scheduled(fixedDelay = 3 * 1000)

2. fixedRate

会根据设置的值, 来预计每次任务应该在什么时候执行。

假定设置的值是 3 秒。那么每个任务预计执行的时间就是 3 秒钟, 定时任务在 7点 0分 0秒 开始执行。

示意图如下:

Spring task中怎么使用定时任务

配置如下:

@Scheduled(fixedRate = 3 * 1000)

3. cron

假定设置的每 5 秒 执行一次,会每隔 5 秒来看一下,上一个任务是否执行完成。

示意图如下:

Spring task中怎么使用定时任务

配置如下:

	@Scheduled(cron = "0/3 * * * * ? ")

思考

问题

了解了 Spring 定时器的三种工作模式后,来思考一个问题,如下面时序图的定时功能?

Spring task中怎么使用定时任务

答案

默认情况下,定时任务是由一个单线程执行的。所以我们需要定义一个线程池去异步执行定时任务。

具体步骤:

  1. 定义一个线程池

     @Configuration
     @EnableAsync
     public class SchedulerAsyncConfig {
    
     	@Bean
     	public Executor taskExecutor(){
     		ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
     		executor.setMaxPoolSize(200);
     		executor.setCorePoolSize(10);
     		executor.setQueueCapacity(10);
     		executor.initialize();
     		return executor;
     	}
    
     }

  2. 在定时任务上加上 @Async 注解。

     @Scheduled(fixedDelay = 10)
     @Async
     public void p1(){
     	System.out.println(Thread.currentThread().getName() + "  p1");
     }

关于 Spring task中怎么使用定时任务问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注创新互联行业资讯频道了解更多相关知识。


新闻标题:Springtask中怎么使用定时任务
文章来源:http://kswjz.com/article/pioioo.html
扫二维码与项目经理沟通

我们在微信上24小时期待你的声音

解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流