zoukankan      html  css  js  c++  java
  • Spring-Task

    Spring-Task

    本文介绍Spring3.0以后自主开发的定时任务工具,spring task,可以将它比作一个轻量级的Quartz,而且使用起来很简单,除spring相关的包外不需要额外的包,而且支持注解和配置文件两种

    形式,下面将分别介绍这两种方式。

    第一种:配置文件方式

    第一步:编写作业类

    即普通的pojo,如下:

    复制代码
    import org.springframework.stereotype.Service;
    @Service
    public class TaskJob {
        
        public void job1() {
            System.out.println(“任务进行中。。。”);
        }
    }
    复制代码

     第二步:在spring配置文件头中添加命名空间及描述

    <beans xmlns="http://www.springframework.org/schema/beans"
        xmlns:task="http://www.springframework.org/schema/task" 
        。。。。。。
        xsi:schemaLocation="http://www.springframework.org/schema/task http://www.springframework.org/schema/task/spring-task-3.0.xsd">

     第三步:spring配置文件中设置具体的任务

     <task:scheduled-tasks> 
            <task:scheduled ref="taskJob" method="job1" cron="0 * * * * ?"/> 
    </task:scheduled-tasks>
    
    <context:component-scan base-package=" com.gy.mytask " />

    说明:ref参数指定的即任务类,method指定的即需要运行的方法,cron及cronExpression表达式,具体写法这里不介绍了,详情见上篇文章附录。

    <context:component-scan base-package="com.gy.mytask" />这个配置不消多说了,spring扫描注解用的。

    到这里配置就完成了,是不是很简单。

    第二种:使用注解形式

    也许我们不想每写一个任务类还要在xml文件中配置下,我们可以使用注解@Scheduled,我们看看源文件中该注解的定义:

    复制代码
    @Target({java.lang.annotation.ElementType.METHOD, java.lang.annotation.ElementType.ANNOTATION_TYPE})
    @Retention(RetentionPolicy.RUNTIME)
    @Documented
    public @interface Scheduled
    {
      public abstract String cron();
    
      public abstract long fixedDelay();
    
      public abstract long fixedRate();
    }
    复制代码

    可以看出该注解有三个方法或者叫参数,分别表示的意思是:

    cron:指定cron表达式

    fixedDelay:官方文档解释:An interval-based trigger where the interval is measured from the completion time of the previous task. The time unit value is measured in milliseconds.即表示从上一个任务完成开始到下一个任务开始的间隔,单位是毫秒。

    fixedRate:官方文档解释:An interval-based trigger where the interval is measured from the start time of the previous task. The time unit value is measured in milliseconds.即从上一个任务开始到下一个任务开始的间隔,单位是毫秒。

    下面我来配置一下。

    第一步:编写pojo

    import org.springframework.scheduling.annotation.Scheduled;  
    import org.springframework.stereotype.Component;
    
    @Component(“taskJob”)
    public class TaskJob {
        @Scheduled(cron = "0 0 3 * * ?")
        public void job1() {
            System.out.println(“任务进行中。。。”);
        }
    }

    第二步:添加task相关的配置:

    复制代码
    <?xml version="1.0" encoding="UTF-8"?>
    <beans xmlns="http://www.springframework.org/schema/beans"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:aop="http://www.springframework.org/schema/aop"
        xmlns:context="http://www.springframework.org/schema/context"
        xmlns:tx="http://www.springframework.org/schema/tx"
        xmlns:task="http://www.springframework.org/schema/task"
        xsi:schemaLocation="
            http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
            http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd
            http://www.springframework.org/schema/context 
    http://www.springframework.org/schema/jdbc/spring-jdbc-3.0.xsd
            http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
            http://www.springframework.org/schema/task http://www.springframework.org/schema/task/spring-task-3.0.xsd"
        default-lazy-init="false">
    
    
        <context:annotation-config />
        <!—spring扫描注解的配置   -->
        <context:component-scan base-package="com.gy.mytask" />
        
    <!—开启这个配置,spring才能识别@Scheduled注解   -->
        <task:annotation-driven scheduler="qbScheduler" mode="proxy"/>
        <task:scheduler id="qbScheduler" pool-size="10"/>
    复制代码

    说明:理论上只需要加上<task:annotation-driven />这句配置就可以了,这些参数都不是必须的。

     Ok配置完毕,当然spring task还有很多参数,我就不一一解释了,具体参考xsd文档http://www.springframework.org/schema/task/spring-task-3.0.xsd。

    附录:

    cronExpression的配置说明,具体使用以及参数请百度google

    字段   允许值   允许的特殊字符

    秒    0-59    , - * /

    分    0-59    , - * /

    小时    0-23    , - * /

    日期    1-31    , - * ? / L W C

    月份    1-12 或者 JAN-DEC    , - * /

    星期    1-7 或者 SUN-SAT    , - * ? / L C #

    年(可选)    留空, 1970-2099    , - * / 

    - 区间  

    * 通配符  

    ? 你不想设置那个字段

    下面只例出几个式子

    CRON表达式    含义 

    "0 0 12 * * ?"    每天中午十二点触发 

    "0 15 10 ? * *"    每天早上10:15触发 

    "0 15 10 * * ?"    每天早上10:15触发 

    "0 15 10 * * ? *"    每天早上10:15触发 

    "0 15 10 * * ? 2005"    2005年的每天早上10:15触发 

    "0 * 14 * * ?"    每天从下午2点开始到2点59分每分钟一次触发 

    "0 0/5 14 * * ?"    每天从下午2点开始到2:55分结束每5分钟一次触发 

    "0 0/5 14,18 * * ?"    每天的下午2点至2:55和6点至6点55分两个时间段内每5分钟一次触发 

    "0 0-5 14 * * ?"    每天14:00至14:05每分钟一次触发 

    "0 10,44 14 ? 3 WED"    三月的每周三的14:10和14:44触发 

    "0 15 10 ? * MON-FRI"    每个周一、周二、周三、周四、周五的10:15触发 

  • 相关阅读:
    Help-Web应用-.Net-Razor界面-入门-添加模型:在 ASP.NET Core 中向 Razor Pages 应用添加模型
    Help-Web应用-.Net-Razor界面-入门-教程:开始使用ASP.NET Core中的Razor Pages
    Help-Web应用-.Net-Razor界面-概述-教程:使用 ASP.NET Core 创建 Razor 页面 Web 应用
    白菜:奶白菜
    白菜:油白菜
    shell中&&和||的使用方法
    ISCSI测试
    iscsi共享分区测试
    RHEL7-openldap安装配置三(客户端自动挂载配置)
    redis配置笔记
  • 原文地址:https://www.cnblogs.com/handsome1013/p/8335594.html
Copyright © 2011-2022 走看看