SpringBoot定时任务实例

SpringBoot定时任务实例

启动类

启动类
1
2
3
4
5
6
7
@EnableScheduling//主要加注这个注解
@SpringBootApplication
public class BigScreenOfTheFirstHospitalApplication {
public static void main(String[] nieqiang) {
SpringApplication.run(BigScreenOfTheFirstHospitalApplication.class, nieqiang);
}
}

定时备份组件

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
import java.io.File;
import java.text.SimpleDateFormat;
import java.util.Date;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;

@Component
public class ScheduledDataBaseBackup {
private static final Logger logger = LoggerFactory.getLogger(ScheduledDataBaseBackup.class);

private static final String dataBackupPath = "F:/backup/";//备份路径
private static final String HOST = "127.0.0.1";//数据库地址
private static final Integer PORT = 3306;//数据库端口
private static final String USERNAME = "root";//数据库用户名
private static final String PASSWORD = "123456";//数据库密码
private static final String dataBaseName = "bigScreen";//数据库名称

//秒 分 小时 月份中的日期 月份 星期中的日期
@Scheduled(cron = "0 0 3 ? * 6")//每个周六晚上3点自动备份数据库
public void backup() throws Exception {
logger.info("开始备份数据库");
String backName = new SimpleDateFormat("yyyy-MM-dd_HH-mm").format(new Date());
dataBaseBackup(HOST, PORT, USERNAME, PASSWORD, dataBaseName, backName);
}

//备份
public static void dataBaseBackup(String host, Integer port, String username, String password, String dataBaseName, String sqlname) throws Exception {
File file = new File(dataBackupPath);
if (!file.exists()) {
file.mkdir();
}
File dataFile = new File(file + File.separator + sqlname + ".sql");
if (dataFile.exists()) {
return;
}
//拼接cmd命令
//mysqldump -hlocalhost -P3306 -uroot -p123456 db > E:/back.sql
StringBuffer s = new StringBuffer();
s.append("cmd /c mysqldump -h").append(host).append(" -P")
.append(port).append(" -u ").append(username).append(" -p")
.append(password).append(" ").append(dataBaseName).append(" > ")
.append(dataFile);
Process exec = Runtime.getRuntime().exec(s.toString());
if (exec.waitFor() == 0){
logger.info("数据库备份成功,备份路径为:{}",dataFile);
}
}
}

corn表达式此示例的原文地址

  • corn表达式一共由七个子表达式组成,前六个必填,最后一个可填,子表达式之间用空格隔开。

    1
    2
    3
    4
    5
    6
    7
    第1位.Seconds(秒)--------------范围(0~59)
    第2位.Minutes(分)--------------范围(0~59)
    第3位.Hours(小时)--------------范围(0~23)
    第4位.Day-of-Month(天)---------范围(1~31,但是要注意有些月份没有31天)
    第5位.Month(月)----------------范围(0~11,或者"JAN, FEB, MAR, APR, MAY, JUN, JUL, AUG, SEP, OCT, NOV,DEC")
    第6位.Day-of-Week(周)----------范围(1~7,1=SUN 或者"SUN, MON, TUE, WED, THU, FRI, SAT”)
    第7位.Year(年)-----------------范围(1970~2099)
  • corn表达式允许特殊的字符(, - * / ? L W C# )且含义如下:

    *————代表所有可能的值。如果在第1位则表示每秒

    -————表示指定范围。如果是在第1位3-20则表示3到20秒

    ,————表示列出枚举值。例如:在第2位,“5,20”表示在5分钟和20分钟触发。

    /:被用于指定增量。例如:在Minutes子表达式中,“0/15”表示从0分钟开始,每15分钟执行一次。”3/20”表示从第三分钟开始,每20分钟执行一次。和”3,23,43”(表示第3,23,43分钟触发)的含义一样。

    ?:用在Day-of-Month和Day-of-Week中,指“没有具体的值”,表示未知。当两个子表达式其中一个被指定了值以后,为了避免冲突,需要将另外一个的值设为“?”。例如:想在每月20日触发调度,不管20号是星期几,只能用如下写法:0 0 0 20 * ?,其中最后一位只能用“?”,而不能用“*”。

    L:用在day-of-month和day-of-week字串中。它是单词“last”的缩写。它在两个子表达式中的含义是不同的。在day-of-month中,“L”表示一个月的最后一天,一月31号,3月30号。在day-of-week中,“L”表示一个星期的最后一天,也就是“7”或者“SAT”;如果“L”前有具体内容,它就有其他的含义了。例如:“6L”表示这个月的倒数第六天。“FRIL”表示这个月的最后一个星期五。注意:在使用“L”参数时,不要指定列表或者范围,这样会出现问题。

    W:“Weekday”的缩写。只能用在day-of-month字段。用来描叙最接近指定天的工作日(周一到周五)。例如:在day-of-month字段用“15W”指“最接近这个月第15天的工作日”,即如果这个月第15天是周六,那么触发器将会在这个月第14天即周五触发;如果这个月第15天是周日,那么触发器将会在这个月第 16天即周一触发;如果这个月第15天是周二,那么就在触发器这天触发。注意一点:这个用法只会在当前月计算值,不会越过当前月。“W”字符仅能在 day-of-month指明一天,不能是一个范围或列表。也可以用“LW”来指定这个月的最后一个工作日,即最后一个星期五。

    #:只能用在day-of-week字段。用来指定这个月的第几个周几。例:在day-of-week字段用”6#3” or “FRI#3”指这个月第3个周五(6指周五,3指第3个)。如果指定的日期不存在,触发器就不会触发。

corn表达式举例

0 * * * * ? -----------------------------每1分钟触发一次
0 0 * * * ? -----------------------------每天每1小时触发一次
0 0 10 * * ? ----------------------------每天10点触发一次
0 * 14 * * ? ----------------------------在每天下午2点到下午2:59期间的每1分钟触发
0 30 9 1 * ? ----------------------------每月1号上午9点半
0 15 10 15 * ? --------------------------每月15日上午10:15触发
*/5 * * * * ? ---------------------------每隔5秒执行一次
0 */1 * * * ? ---------------------------每隔1分钟执行一次
0 0 5-15 * * ? --------------------------每天5-15点整点触发
0 0/3 * * * ? ---------------------------每三分钟触发一次
0 0-5 14 * * ? --------------------------在每天下午2点到下午2:05期间的每1分钟触发
0 0/5 14 * * ? --------------------------在每天下午2点到下午2:55期间的每5分钟触发
0 0/5 14,18 * * ? -----------------------在每天下午2点到2:55期间和下午6点到6:55期间的每5分钟触发
0 0/30 9-17 * * ? -----------------------朝九晚五工作时间内每半小时
0 0 10,14,16 * * ? ----------------------每天上午10点,下午2点,4点
0 0 3 ? * 6------------------------------表示每个星期三中午12点
0 0 17 ? * TUES,THUR,SAT ----------------每周二、四、六下午五点
0 10,44 14 ? 3 WED ----------------------每年三月的星期三的下午2:10和2:44触发
0 15 10 ? * MON-FRI ---------------------周一至周五的上午10:15触发
0 0 23 L * ? ----------------------------每月最后一天23点执行一次
0 15 10 L * ? ---------------------------每月最后一日的上午10:15触发
0 15 10 ? * 6L --------------------------每月的最后一个星期五上午10:15触发
0 15 10 * * ? 2005 ----------------------2005年的每天上午10:15触发
0 15 10 ? * 6L 2002-2005 ----------------2002年至2005年的每月的最后一个星期五上午10:15触发
0 15 10 ? * 6#3 -------------------------每月的第三个星期五上午10:15触发

cron表达式生成工具

评论