博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
java中添加定时任务
阅读量:5897 次
发布时间:2019-06-19

本文共 4771 字,大约阅读时间需要 15 分钟。

第一种方式:

springMvc.xml中

1.xmlns:task="http://www.springframework.org/schema/task"   
 
2.http://www.springframework.org/schema/task
  http://www.springframework.org/schema/task/spring-task-4.1.xsd  
                            
3.    
<context:component-scan base-package=" com.djzh.common.* " />
<!-- 开启这个配置,spring才能识别@Scheduled注解 -->
<task:annotation-driven scheduler="qbScheduler" mode="proxy" />
<task:scheduler id="qbScheduler" pool-size="10" />

 

 第二种方式:spring + quartz 定义定时任务:

spring 管理quartz 有两种方式:

1):自定义的任务类继承特定的基类 QuartzJobBean 

2):自定义的任务类不继承特定的基类  完全就是一个普通的pojo :这种方式的实现主要是spring下的类:org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean

这里只讲述第二种实现方式:

1.定义任务

public class ActQuartz {

  public void adjustProbability(){

    logger.info("开始调整概率定时任务!");

  }

}

2.spring-quartz.xml的配置如下所示:

<!-- 活动中奖概率调整定时任务 -->

<bean id="actQuartz" class="com.psbc.quartz.ActQuartz" />
<!-- 定义调用对象和调用对象的方法 -->
  <bean id="actDetail"
    class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
    <!-- 调用的类 -->
    <property name="targetObject" ref="actQuartz" />
    <!-- 调用类中的方法 -->
    <property name="targetMethod" value="adjustProbability" />
    <!-- 是否允许任务并发执行。当值为false时,表示必须等到前一个线程处理完毕后才再启一个新的线程 -->
    <property name="concurrent" value="false"/>
</bean>

<!-- 初始化调用的 -->
  <bean id="actInitDao" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
    <!-- 调用的类 -->
    <property name="targetObject" ref="actQuartz" />
    <!-- 调用类中的方法 -->
    <property name="targetMethod" value="initDao" />
    <!-- 是否允许任务并发执行。当值为false时,表示必须等到前一个线程处理完毕后才再启一个新的线程 -->
    <property name="concurrent" value="false"/>
  </bean>

<!-- 定义触发时间,每天23点59分触发 -->
  <bean id="actTrigger"
    class="org.springframework.scheduling.quartz.CronTriggerFactoryBean">
    <property name="jobDetail">
    <ref bean="actDetail" />
    </property>
    <property name="cronExpression">
    <value>0 45 9 * * ?</value>
    </property>
  </bean>

<!-- 配置项目启动后任务就执行一次 -->
  <bean id="initActTrigger" class="org.springframework.scheduling.quartz.SimpleTriggerFactoryBean">
    <property name="jobDetail" ref="actInitDao" />
    <property name="startDelay" value="10000" />
    <property name="repeatInterval" value="0" />
    <property name="repeatCount" value="0" />
  </bean> 

3.这个是quartz的语法 定时单位

0 0 10,14,16 * * ? 每天上午10点,下午2点,4点

0 0/30 9-17 * * ? 朝九晚五工作时间内每半小时

0 0 12 ? * WED 表示每个星期三中午12点

"0 0 12 * * ?" 每天中午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期间的每1分钟触发

"0 0/5 14 * * ?" 在每天下午2点到下午2:55期间的每5分钟触发

"0 0/5 14,18 * * ?" 在每天下午2点到2:55期间和下午6点到6:55期间的每5分钟触发

"0 0-5 14 * * ?" 在每天下午2点到下午2:05期间的每1分钟触发

"0 10,44 14 ? 3 WED" 每年三月的星期三的下午2:10和2:44触发

"0 15 10 ? * MON-FRI" 周一至周五的上午10:15触发

"0 15 10 15 * ?" 每月15日上午10:15触发

"0 15 10 L * ?" 每月最后一日的上午10:15触发

"0 15 10 ? * 6L" 每月的最后一个星期五上午10:15触发

"0 15 10 ? * 6L 2002-2005" 2002年至2005年的每月的最后一个星期五上午10:15触发

"0 15 10 ? * 6#3" 每月的第三个星期五上午10:15触发 

这里触发器的定义有两种方式:

1:SimpleTriggerBean:

2:CronTriggerBean:

用户可以根据自身的需要来选择相应的触发器;

这里需要注意的是 org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean这个类是在spring-context-support这个包下的,需要引入这个

依赖;配置完了定时spring定时job后,需要注册监听器来监听开启spring-quartz.xml,我这里用的是在web.xml中配置监听项目启动后开启spring-quartz.xml容器;

 

第三种方式:java+Quartz实现定时任务:

首先:导入quartz相关的jar包,这里我用的是maven构建的项目,pom.xml文件导入如下:

org.quartz-scheduler
quartz
2.2.1
org.quartz-scheduler
quartz-jobs
2.2.1
定义要进行定时任务类(该类实现了Quartz 下的job类):
public class MyJob implements Job{    @Override    public void execute(JobExecutionContext arg0) throws JobExecutionException {        // TODO Auto-generated method stub        System.out.println("开启了定时任务");            }}

接下来要做的就是按照定时任务的固定步骤来做即可:1:定义调度器并且开启   2:定义任务器  3:定义触发器   4 注册 

 

  public class QuartzDemo {

  public void quartzTest() throws InterruptedException{

     try { //获取调度器

       Scheduler scheduler = StdSchedulerFactory.getDefaultScheduler(); scheduler.start();

      //创建任务器:定义任务细节

      JobDetail jobDetail = JobBuilder.newJob(MyJob.class).withIdentity("job1", "group1").build();

       ScheduleBuilder scheduleBuilder =SimpleScheduleBuilder.simpleSchedule().withIntervalInSeconds(5).repeatForever();

       //定义触发器

      Trigger trigger=TriggerBuilder.newTrigger().withIdentity("simpleTrigger", "simpleTriggerGroup") .withSchedule(scheduleBuilder).startNow().build();

       //将任务和触发器注册到调度器中

       scheduler.scheduleJob(jobDetail, trigger); Thread.sleep(1000*30); // scheduler.shutdown();

       } catch (SchedulerException e) { // TODO Auto-generated catch block e.printStackTrace(); } }

转载于:https://www.cnblogs.com/523823-wu/p/7787801.html

你可能感兴趣的文章
Jdom的简单操作
查看>>
left join on/right join on/inner join on/full join on连接
查看>>
Codeforces 582B Once Again
查看>>
template.helper 多参数
查看>>
RadioButton布局图片+文字 实现tabhost效果
查看>>
[HEOI2012]采花
查看>>
access中设置不等于
查看>>
hdu 1221 Rectangle and Circle
查看>>
Android 四大组件之四(ContentProvider)
查看>>
Android 四大组件之一(Activity)
查看>>
扫描(一)
查看>>
MySQLDump在使用之前一定要想到的事情 [转载]
查看>>
PIE SDK矢量数据的读取
查看>>
win10安装tomcat9
查看>>
两种方式分别改变alertdialog的宽和高
查看>>
TextView-setCompondDrawables用法
查看>>
由扭结理论中的琼斯多项式的证明想到的
查看>>
淘宝Hadoop集群的概况
查看>>
Centos7安装rabbitmq server 3.6.0
查看>>
关于eclipse的ADT(插件)对xml的android:text属性检查修改
查看>>