spring的定时任务@Scheduled(cron = "0 0 0 * * ?")

本文介绍如何使用Spring框架实现定时任务,以借贷公司提醒客户还款为例,详细解释了配置方法及cron表达式的使用。

初次接触spring的定时任务记录一下

业务场景:某借贷公司的借贷订单需要在借款时间到期的前一天和当天分配提醒人员提醒客户还款。

这样的需求就需要用到定时去完成

配置的话因搭建的框架有关就不记录

首先在需要定时任务的类上加上@Component这个的作用就是把普通的pojo实例化到spring的容器中,相当于配置文件中的

<bean  id = ""  class =""/>

日志最好打印出来方便找问题

private static final Logger LOGGER=loggerFactory.getLogger(传入你自己类.class);

而后就是在你需要定时的方法上面加入

@Scheduled(cron=""这个里面的是cron表达式)

cron表达式的长度为6个或者是7个

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

依次为:秒、分、时、日、月、周、年(可选)

秒(0~59) 分钟(0~59) 小时(0~23) 日(0~31) 月(0~11) 星期(1~7 1为SUN-依次为SUN,MON,TUE,WED,THU,FRI,SAT)

字段名                 允许的值                        允许的特殊字符
  秒 0-59 , - * /
  分 0-59 , - * /
  小时 0-23 , - * /
  日 1-31 , - * ? / L W C
  月 1-12 or JAN-DEC , - * /
  周几 1-7 or SUN-SAT , - * ? / L C #
  年 (可选字段) empty, 1970-2099 , - * /
*” 代表整个时间段. 
  每一个字段都有一套可以指定有效值,如 
  Seconds (秒)         :可以用数字0-59 表示,
  Minutes(分)          :可以用数字0-59 表示,
  Hours(时)             :可以用数字0-23表示, 
  Day-of-Month(天) :可以用数字1-31 中的任一一个值,但要注意一些特别的月份 
  Month(月)            :可以用0-11 或用字符串  “JAN, FEB, MAR, APR, MAY, JUN, JUL, AUG, SEP, OCT, NOV and DEC” 表示
  Day-of-Week(每周):可以用数字1-7表示(1 = 星期日)或用字符口串“SUN, MON, TUE, WED, THU, FRI and SAT”表示  
  “/”:为特别单位,表示为“每”如“0/15”表示每隔15分钟执行一次,“0”表示为从“0”分开始, “3/20”表示表示每隔20分钟执行一次,“3”表示从第3分钟开始执行  
  “?”:表示每月的某一天,或第周的某一天  
  “L”:用于每月,或每周,表示为每月的最后一天,或每个月的最后星期几如“6L”表示“每月的最后一个星期五”  
  “W”:表示为最近工作日,如“15W”放在每月(day-of-month)字段上表示为“到本月15日最近的工作日”  
  ““#”:是用来指定“的”每月第n个工作日,例 在每周(day-of-week)这个字段中内容为"6#3" or "FRI#3" 则表示“每月第三个星期五”
Cron表达式范例:
每隔5秒执行一次:*/5 * * * * ?
每隔1分钟执行一次:0 */1 * * * ?
每天23点执行一次:0 0 23 * * ?
每天凌晨1点执行一次:0 0 1 * * ?
每月1号凌晨1点执行一次:0 0 1 1 * ?
每月最后一天23点执行一次:0 0 23 L * ?
每周星期天凌晨1点实行一次:0 0 1 ? * L

然后方法中就是需要定时任务的执行代码

/**
 * 订单到期提醒,分配当前处理人
 *
 * @author 
 * @Date: 
 */
@Component
public class LoanRemindTask {
    private static final Logger LOGGER = LoggerFactory.getLogger(LoanRemindTask.class);

    @Autowired
    private ILoanComponent loanComponent;

    @Autowired
    private ILoanExtComponent loanExtComponent;

    @Autowired
    IGroupUserComponent groupUserComponent;

//        @Scheduled(cron = "*/3 * * * * ?")
    @Scheduled(cron = "0 0 0 * * ?")
    private void process() {
        loanExpire();
    }

    private void loanExpire() {
        LOGGER.info("到期提醒task开始");
        //状态为AUDITED 且还款日等于当天,提醒还款
        AvatarLoanExample example = new AvatarLoanExample();
        AvatarLoanExample.Criteria criteria = example.createCriteria();
        String status[] = {LoanStatusEnum.AUDITED.getCode()};
        criteria.andStatusIn(Arrays.asList(status));
        criteria.andEndDateEqualTo(new Date());

        List<LoanBean> loanList = loanComponent.getList(example);
        String bizGroup = GroupUserEnum.T001.getCode();
        List<String> groupUser = groupUserComponent.getLoginNameList(bizGroup).stream().map(a -> a.getLoginName()).collect(Collectors.toList());

        if (loanList.isEmpty() && groupUser.isEmpty()) {
            return;
        }
        int i = 0;
        for (LoanBean loanBean : loanList) {
            try {
                LoanExtBean bean = loanExtComponent.getBean(loanBean.getLoanNo());
                bean.setHandler(groupUser.get(i));
                loanExtComponent.updateBean(bean);
                if (i == groupUser.size()-1) {
                    i = 0;
                    i--;
                }
                i++;
            } catch (Exception e) {
                LOGGER.error(e.getMessage(), e);
            }
        }
        LOGGER.info("提醒task结束");
    }
}

### 含义 `@Scheduled(cron = &quot;0 * * * * ? &quot;)` 是 Spring 框架中用于定时任务调度的注解配置。其中 `cron` 表达式 `&quot;0 * * * * ? &quot;` 规定了任务的执行时间。按照 cron 表达式各占位符的规则: - `{秒数}` 位置是 `0`,表示在每分钟的第 0 秒触发任务。 - `{分钟}` 位置是 `*`,代表每分钟都触发。 - `{小时}`、`{日期}`、`{星期}` 位置的 `*` 分别表示每小时、每天、每周都执行。 - `{年份}` 位置被省略,意味着默认在所有合法年份都执行。`?` 用于 `{日期}` 和 `{星期}` 中互斥时使用,这里表示不指定具体的日期或星期,避免冲突。所以该表达式整体含义是每分钟的第 0 秒触发一次任务 [^3][^4]。 ### 使用方法 以下是一个使用 `@Scheduled(cron = &quot;0 * * * * ? &quot;)` 的示例代码: ```java import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; import java.text.SimpleDateFormat; import java.util.Date; @Component public class ScheduledTask { @Scheduled(cron = &quot;0 * * * * ? &quot;) public void executeTask() { SimpleDateFormat sdf = new SimpleDateFormat(&quot;yyyy-MM-dd HH:mm:ss&quot;); System.out.println(&quot;任务执行时间:&quot; + sdf.format(new Date())); } } ``` 要使上述代码生效,还需要在 Spring Boot 主类上添加 `@EnableScheduling` 注解来开启定时任务功能: ```java import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.scheduling.annotation.EnableScheduling; @SpringBootApplication @EnableScheduling public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } } ``` ### 相关配置说明 `@Scheduled` 注解有多种配置参数,各参数说明如下: - `cron`:cron 表达式是一个字符串,常用于各种定时任务解决方案,如 `&quot;0/30 * * * * ?&quot;` 。 - `zone`:用来解析 cron 表达式中的时区,默认取服务器所在时区,例如 `GMT - 12:00`。 - `fixedDelay`:上一次执行完毕时间点到下一次执行开始时间点之间的时间,单位为毫秒,如 `5000`。 - `fixedDelayString`:与 `fixedDelay` 类似,只是使用字符串的形式,如 `&quot;5000&quot;`。 - `fixedRate`:上一次执行开始时间点经过多长时间再次执行,单位为毫秒,如 `5000`。 - `fixedRateString`:与 `fixedRate` 类似,使用字符串的形式,如 `&quot;5000&quot;`。 - `initialDelay`:第一次执行任务前延误时间,单位为毫秒,如 `2000`。 - `initialDelayString`:与 `initialDelay` 类似,使用字符串的形式,如 `&quot;2000&quot;` [^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值