前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >SpringBoot整合定时任务----Scheduled注解实现(一个注解全解决)

SpringBoot整合定时任务----Scheduled注解实现(一个注解全解决)

作者头像
掉发的小王
发布2022-07-11 15:39:51
5250
发布2022-07-11 15:39:51
举报
文章被收录于专栏:小王知识分享小王知识分享

一、使用场景

定时任务在开发中还是比较常见的,比如:定时发送邮件,定时发送信息,定时更新资源,定时更新数据等等...

二、准备工作

在Spring Boot程序中不需要引入其他Maven依赖 (因为spring-boot-starter-web传递依赖了spring-context模块)

代码语言:javascript
复制
<dependency>
	<groupId>org.springframework.boot</groupId>
	<artifactId>spring-boot-starter-web</artifactId>
</dependency>

三、开始搭建配置

  • 配置启动项
代码语言:javascript
复制
package com.wang.test.demo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.scheduling.annotation.EnableScheduling;

@SpringBootApplication
@EnableScheduling//启动定时任务
public class DemoApplication {

    public static void main(String[] args) {
        SpringApplication.run(DemoApplication.class, args);
    }

}
  • cron表达式

关于cron表达式,小编这里不做过多介绍,这里是cron生成器,大家可以参考 https://www.matools.com/cron/

  • 定时任务方法
代码语言:javascript
复制
package com.wang.test.demo.task;

import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;

@Component//加载到容器中,可以被发现启动
public class TaskTest {

	//cron表达式,来控制定时执行时间,这里是每5秒执行一次本方法,业务逻辑可以进行在此方法内进行书写
    @Scheduled(cron = "0/5 * * * * ?")
    public void printTimeOne(){

        System.out.println("任务一:时间为-->"+System.currentTimeMillis());
    }

    @Scheduled(cron = "0/6 * * * * ?")
    public void printTimeTwo(){

        System.out.println("任务二:时间为-->"+System.currentTimeMillis());

    }

}

四、结果展示

在这里插入图片描述
在这里插入图片描述

五、总结

这样就完整了SpringBoot整合定时任务了,一个注解全搞定,非常简洁好懂.

Q.E.D.

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-01-13,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、使用场景
  • 二、准备工作
  • 三、开始搭建配置
  • 四、结果展示
  • 五、总结
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档