定时任务
# 定时任务
对于简单的定时任务用 Spring的 @Scheduled 注解即可,如需要动态管理定时任务就需要使用到 Quartz。
本系统的动态定时任务源码位于 eldamin-module-system -> cn.odboy.system.framework.quartz,使用流程如下
# 任务处理类
新版本加入了验证是不是合法的Bean,合法的定时任务 Bean 需要用 @Service 定义,原因: 避免调用攻击者可以从SpringContextHolder获得控制jdbcTemplate类,并使用getDeclaredMethod调用jdbcTemplate的queryForMap函数,执行任意sql命令。
@Slf4j
@Service
public class TestTask {
public void run() {
log.info("run 执行成功");
}
public void run1(String str) {
log.info("run1 执行成功, 参数为: {}", str);
}
public void run2() {
log.info("run2 执行成功");
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
2
3
4
5
6
7
8
9
10
11
12
13
14
15
源码位置 cn.odboy.system.job.TestTask
# 创建定时任务
打开定时任务页面,点击新增按钮创建定时任务,部分参数解释如下:
- Bean名称:Spring Bean名称,如: testTask
- 方法名称:对应后台任务方法名称 方法参数:对应后台任务方法名称值,没有可不填
- cron表达式:可查询官方cron表达式介绍
- 任务负责人与告警邮箱:支持多个邮箱,定时任务执行失败邮箱提醒
- 子任务ID:现支持添加子任务,支持多个子任务,按顺序执行
- 状态:是否启动定时任务
# Cron表达式
# 五段Cron表达式的格式
* * * * *
- - - - -
| | | | |
| | | | +-- 月份 (1-12 或 JAN-DEC)
| | | +---- 日期 (1-31)
| | +------ 小时 (0-23)
| +-------- 分钟 (0-59)
+---------- 秒 (0-59)
1
2
3
4
5
6
7
8
2
3
4
5
6
7
8
# 常见表达式
0 0 12 * * # 每天中午12点触发
0 15 10 * * # 每天上午10:15触发
0 0/30 9-17 * * # 每天9点到17点之间每隔30分钟触发
0 0 1 1 * # 每年1月1日凌晨1点触发
0 0 23 L * # 每月最后一天23点触发
0 0 1 ? * 7 # 每周日凌晨1点触发
1
2
3
4
5
6
2
3
4
5
6
帮助我们改善此页面! (opens new window)