1、在启动类上写@EnableScheduling注解
package com.mryx.matrix.codeanalyzer.web; import org.mybatis.spring.annotation.MapperScan; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.boot.web.servlet.ServletComponentScan; import org.springframework.context.annotation.ComponentScan; import org.springframework.scheduling.annotation.EnableScheduling; @EnableScheduling @SpringBootApplication @ComponentScan("com.mryx.matrix.codeanalyzer") @MapperScan("com.mryx.matrix.codeanalyzer.core.dao") @ServletComponentScan("com.mryx.matrix.codeanalyzer.web.filter") public class MatrixCodeAnalyzerApplication { private static final Logger LOGGER = LoggerFactory.getLogger(MatrixCodeAnalyzerApplication.class); private static Integer taskId = 0; public static void main(String[] args) { SpringApplication.run(MatrixCodeAnalyzerApplication.class, args); LOGGER.info("MatrixCodeAnalyzerApplication start success!"); } }
2、在要定时任务的类上写@component
3、在要定时执行的方法上写@Scheduled(cron = "0 0/5 * * * ?")。
package com.mryx.matrix.codeanalyzer.web.job; import com.mryx.matrix.codeanalyzer.core.service.ProjectCodeScanTaskService; import com.mryx.matrix.codeanalyzer.domain.CodeScanResult; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; import javax.annotation.Resource; import java.text.SimpleDateFormat; import java.util.Date; import java.util.List; @Component public class CodeScanJob { private static final Logger logger = LoggerFactory.getLogger(CodeScanJob.class); private static Integer job = 0; @Resource private ProjectCodeScanTaskService projectCodeScanTaskService; //表示每5分钟执行 @Scheduled(cron = "0 0/5 * * * ?") public void cronJob() throws InterruptedException { List<CodeScanResult> infos = projectCodeScanTaskService.getCodeScanInfo(); Integer id = 0; for (CodeScanResult info : infos) { ++id; logger.info("id : {} {} {} {} {}", info.getId(), info.getTypeOfScan(), info.getAppCode(), info.getCodeBranch(), info.getGitAddress()); SimpleDateFormat sf = new SimpleDateFormat("yyyyMMddHHmmss"); String datetime = sf.format(new Date()); String taskName = datetime + "job" + id; info.setTaskName(taskName); projectCodeScanTaskService.createCodeScanJob(info); Thread.sleep(20000); } logger.info("第{}次Job执行完成,共有{}个Job", ++job, id); } }
cron表达式:
* 第一位,表示秒,取值0-59
* 第二位,表示分,取值0-59
* 第三位,表示小时,取值0-23
* 第四位,日期天/日,取值1-31
* 第五位,日期月份,取值1-12
* 第六位,星期,取值1-7,星期一,星期二...,注:不是第1周,第二周的意思,另外:1表示星期天,2表示星期一。
* 第7为,年份,可以留空,取值1970-2099
(*)星号:可以理解为每的意思,每秒,每分,每天,每月,每年...
(?)问号:问号只能出现在日期和星期这两个位置。
(-)减号:表达一个范围,如在小时字段中使用“10-12”,则表示从10到12点,即10,11,12
(,)逗号:表达一个列表值,如在星期字段中使用“1,2,4”,则表示星期一,星期二,星期四
(/)斜杠:如:x/y,x是开始值,y是步长,比如在第一位(秒) 0/15就是,从0秒开始,每15秒,最后就是0,15,30,45,60 另:*/y,等同于0/y
eg:
0 3 * * ? 每天3点执行
5 3 * * ? 每天3点5分执行
5 3 ? * * 每天3点5分执行,与上面作用相同
5/10 3 * * ? 每天3点的 5分,15分,25分,35分,45分,55分这几个时间点执行
10 3 ? * 1 每周星期天,3点10分 执行,注:1表示星期天
10 3 ? * 1#3 每个月的第三个星期,星期天 执行,#号只能出现在星期的位置
参考:https://www.cnblogs.com/qdhxhz/p/9058418.html