Java任务调度

1.Spring任务调度之Spring-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:p="http://www.springframework.org/schema/p"
	xmlns:context="http://www.springframework.org/schema/context"
	xmlns:task="http://www.springframework.org/schema/task"	
	xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd
        http://www.springframework.org/schema/task http://www.springframework.org/schema/task/spring-task-4.2.xsd">
    <task:annotation-driven/>
</beans>
②类上添加注解:
@Component
  方法上添加注解:
@Scheduled(cron="* * * * * ?")
2.Quartz介绍:Quartz是一个开源的作业调度框架
实现步骤:
①写一个要调度的方法:
	public void testQuartz() {
		System.out.println("---------:"+new Date());
	}
②applicationContext-quartz.xml中:
 <!-- 定义一个任务类 -->
<bean id="testBean" class="com.neusoft.service.impl.TestSpringServiceImpl"></bean>
<!-- 任务类描述 -->
<bean id="testBeanDetail" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
	<property name="targetObject" ref="testBean"></property>
	<property name="targetMethod" value="testQuartz"></property>
</bean>
<!-- 触发器  -->
<bean id="testTrigger" class="org.springframework.scheduling.quartz.CronTriggerFactoryBean">
	<property name="jobDetail" ref="testBeanDetail"></property>
	<!-- 表达式,每天的9:15:30  和 18:15:30 执行 -->
	<property name="cronExpression" value="30 15 9,18 * * ? *"></property>
	<!-- <property name="cronExpression" value="0/10 * * * * ? *"></property> -->
</bean>
<!-- 总管理容器 -->
<bean id="startQuartz" class="org.springframework.scheduling.quartz.SchedulerFactoryBean" >
	<property name="triggers">
		<list>
			<ref bean="testTrigger"/>
		</list>
	</property>
</bean>

3.定时器的时间格式

QuartzCron表达式支持到六到七个域 

名称 是否必须 特殊字符 特殊字符
0-59 , - * /
0-59 , - * /
0-23 , - * /
1-31 , - * ? / L W C
1-12 货JAN-DEC , - * /
1-7 或 SUN-SAT , - * ? / L C #
空 或 1970-2099 , - * /
(1)*:表示匹配该域的任意值,假如在Minutes域使用*, 即表示每分钟都会触发事件。
(2)?:只能用在DayofMonth和DayofWeek两个域。它也匹配域的任意值,但实际不会。因为DayofMonth和 DayofWeek会相互影响。例如想在每月的20日触发调度,不管20日到底是星期几,则只能使用如下写法: 13 13 15 20 * ?, 其中最后一位只能用?,而不能使用*,如果使用*表示不管星期几都会触发,实际上并不是这样。 
(3)-:表示范围,例如在Minutes域使用5-20,表示从5分到20分钟每分钟触发一次 
(4)/:表示起始时间开始触发,然后每隔固定时间触发一次,例如在Minutes域使用5/20,则意味着5分钟触发一次,而25,45等分别触发一次. 
(5),:表示列出枚举值值。例如:在Minutes域使用5,20,则意味着在5和20分每分钟触发一次。 
(6)L:表示最后,只能出现在DayofWeek和DayofMonth域,如果在DayofWeek域使用5L,意味着在最后的一个星期四触发。 
(7)W: 表示有效工作日(周一到周五),只能出现在DayofMonth域,系统将在离指定日期的最近的有效工作日触发事件。例如:在 DayofMonth使用5W,如果5日是星期六,则将在最近的工作日:星期五,即4日触发。如果5日是星期天,则在6日(周一)触发;如果5日在星期一 到星期五中的一天,则就在5日触发。另外一点,W的最近寻找不会跨过月份 
(8)LW:这两个字符可以连用,表示在某个月最后一个工作日,即最后一个星期五。 
(9)#:用于确定每个月第几个星期几,只能出现在DayofMonth域。例如在4#2,表示某月的第二个星期三。

4.分布式任务调度 SchedulerX

SchedulerX 是阿里中间件团队开发的一款分布式任务调度产品。SchedulerX-Server 集群为调度触发提供高可用性和高稳定性的保证,并且可以实现对您的客户端机器集群进行分布式调度。
①功能特性
分布式
高可用
轻量服务
简单易用
支持 Quartz 时间表达式
友好的用户界面
②应用场景
固定时间点触发的任务
例如:2016年11月11日0点执行的一次任务。
周期性触发的任务
例如:每秒钟(或者每小时、每天、每星期、每月等)执行一次的任务。
通过控制台手动触发的任务
例如:您可以通过控制台手动触发任务的调度执行。任务触发执行后,由 Job 处理器接口中的代码决定具体要完成的业务逻辑功能(例如扫表、触发 RPC 调用、入库、执行本地脚本等)。
③快速入门(见阿里官网开发文档)
https://help.aliyun.com/document_detail/35359.html?spm=a2c4g.11186623.6.825.0atUsO

猜你喜欢

转载自blog.csdn.net/zhou870498/article/details/80685580