Spring4.X + spring MVC + Mybatis3 零配置应用开发框架搭建详解(4) - Scheduled注解实现任务调度
1. 创建定时调度任务
很多项目都需要通过调度任务去完成一些非交互性的工作,比如定时更新数据库,定时统计上一天的数据等等。在零配置框架中,我们使用@
Scheduled完成定时任务的处理,一个类,一个注释,整个调度器就搞定了。
首先,我们在【task】项目中创建【com.aitongiy.web.task】包
![](https://img-blog.csdn.net/20160815145342257?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
然后创建【CustomTask.Java】
- import org.slf4j.Logger;
- import org.slf4j.LoggerFactory;
- import org.springframework.scheduling.annotation.Scheduled;
- import org.springframework.stereotype.Component;
-
- /**
- * 自定义定时任务
- * Created by admin on 16/8/15.
- */
- @Component
- public class CustomTask {
- private static final Logger logger = LoggerFactory.getLogger(CustomTask.class);
-
-
- /**
- * 调度任务执行
- * <pre>
- * <table>
- * <th>
- * <tr> <td>名称</td> <td>类型</td> <td>单位</td><td>说明</td> </tr>
- * </th>
- *
- * <tr> <td>cron</td> <td>String</td> <td> - </td> <td>cron表达式</td></tr>
- * <tr> <td>zone</td> <td>String</td> <td> - </td> <td>时区字符串(一般不需要设置)</td> </tr>
- * <tr> <td>fixedDelay</td> <td>long</td> <td>毫秒</td> <td>调度间隔,下一个任务开始时间与上一个任务结束时间间隔[F-S]</td> </tr>
- * <tr> <td>fixedDelayString</td> <td>String</td> <td>毫秒</td> <td>调度间隔,下一个任务开始时间与上一个任务结束时间间隔,字符串表示[F-S]</td> </tr>
- * <tr> <td>fixedRate</td> <td>long</td> <td>毫秒</td> <td>调度间隔,下一个任务开始时间与上一个任务开始时间间隔[S-S]</td> </tr>
- * <tr> <td>fixedRateString</td> <td>String</td> <td>毫秒</td> <td>调度间隔,下一个任务开始时间与上一个任务开始时间间隔,字符串表示[S-S]</td> </tr>
- * <tr> <td>initialDelay</td> <td>long</td> <td>毫秒</td> <td>调度器启动延迟时间</td> </tr>
- * <tr> <td>initialDelayString</td> <td>String</td> <td>毫秒</td> <td>调度器启动延迟时间,字符串表示</td> </tr>
- *
- * </table>
- * </pre>
- */
- @Scheduled(fixedRate = 1000 * 10,initialDelay = 1000 * 5)
- private void taskRun(){
- logger.info("CustomTask run ...");
- }
- }
方法上的@Scheduled有几个配置参数,我看通过下面的表查可以了解一下。
|
---|
名称 | 类型 | 单位 | 说明 |
cron | String | - | cron表达式 |
zone | String | - | 时区字符串(一般不需要设置) |
fixedDelay | long | 毫秒 | 调度间隔,下一个任务开始时间与上一个任务结束时间间隔[F-S] |
fixedDelayString | String | 毫秒 | 调度间隔,下一个任务开始时间与上一个任务结束时间间隔,字符串表示[F-S] |
fixedRate | long | 毫秒 | 调度间隔,下一个任务开始时间与上一个任务开始时间间隔[S-S] |
fixedRateString | String | 毫秒 | 调度间隔,下一个任务开始时间与上一个任务开始时间间隔,字符串表示[S-S] |
initialDelay | long | 毫秒 | 调度器启动延迟时间 |
initialDelayString | String | 毫秒 | 调度器启动延迟时间,字符串表示 |
2. 添加定时调度配置
然后我们需要在【back】项目的【MvcConfig.java】中的【@ConponentScan】注释中加入【com.aitongyi.web.task】
- @EnableWebMvc
- @EnableAspectJAutoProxy
- @EnableScheduling
- @ComponentScan(basePackages =
- {"com.aitongyi.web.back.controller",
- "com.aitongyi.web.service",
- "com.aitongyi.web.task"})
- @MapperScan("com.aitongyi.web.dao.mapper")
添加完成后,我们要在【back】项目的pom.xml文件中添加task任务的依赖,要不然【back】项目中无法扫描到【task】项目中的类
- <dependencies>
- <dependency>
- <groupId>com.aitongyi.web</groupId>
- <artifactId>dao</artifactId>
- <version>${project.version}</version>
- </dependency>
- <dependency>
- <groupId>com.aitongyi.web</groupId>
- <artifactId>bean</artifactId>
- <version>${project.version}</version>
- </dependency>
- <dependency>
- <groupId>com.aitongyi.web</groupId>
- <artifactId>service</artifactId>
- <version>${project.version}</version>
- </dependency>
- <dependency>
- <groupId>com.aitongyi.web</groupId>
- <artifactId>task</artifactId>
- <version>${project.version}</version>
- </dependency>
添加完成后,我们启动【back】服务,服务启动完成,看看日志,我们就知道它运行起来了,
- [INFO ][12:25:47] - [com.aitongyi.web.task.CustomTask] - CustomTask run ...
- [INFO ][12:25:47] - [com.aitongyi.web.task.CustomTask] - CustomTask run ...
- [INFO ][12:25:47] - [com.aitongyi.web.task.CustomTask] - CustomTask run ...
- [INFO ][12:25:47] - [com.aitongyi.web.task.CustomTask] - CustomTask run ...
- [INFO ][12:25:47] - [com.aitongyi.web.task.CustomTask] - CustomTask run ...
- [INFO ][12:25:47] - [com.aitongyi.web.task.CustomTask] - CustomTask run ...
注解方式的定时任务已经配置完成了,不过我们需要分析一下,这个注解方式的调度任务的优缺点:
优点:配置简单、高效
缺点:定时规则是写死的,无法进行配置,需要更新代码才能更改调度规则。
如果你的调度规则经常变化,就只能用XML的方式或者编程的方式手动处理,xml的方式是调度规则可灵活配置,代码中控制的方式是可以通过数据库,web的方式实现在线查看运行状态的处理,更灵活。
后期我会提供代码方式的示例。今天就暂时写到这里。
目录