Java에서 예약된 작업을 구현하는 방법: 1. Java와 함께 제공되는 "java.util.Timer" 클래스를 사용하면 "java.util.TimerTask" 작업을 예약할 수 있습니다. 2. Quartz를 사용합니다. Spring3.0에는 작업이 포함되어 있습니다.
이 튜토리얼의 운영 환경: windows7 시스템, java8 버전, DELL G3 컴퓨터.
최근에는 프로젝트 개발 중에 일부 예정된 작업을 수행해야 합니다. 예를 들어 매일 이른 아침에 전날의 로그 정보를 분석해야 하는 경우가 있습니다. 이 기회에 예정된 작업의 여러 구현 방법을 정리했습니다. 본 프로젝트는 스프링 프레임워크를 사용하고 있기 때문에 스프링 프레임워크와 연계하여 소개하겠습니다.
1. Java 고유의 java.util.Timer 클래스를 사용하면 TimerTask 작업을 예약할 수 있습니다. . 이 방법을 사용하면 프로그램이 특정 빈도로 실행될 수 있지만 지정된 시간에는 실행되지 않습니다. 일반적으로 덜 사용되므로 이 기사에서는 자세히 소개하지 않습니다.
2. 특정 시간이나 특정 빈도로 프로그램을 실행할 수 있는 비교적 강력한 스케줄러인 Quartz를 사용하세요. 구성이 약간 복잡하므로 나중에 자세히 소개하겠습니다.
3. Spring 3.0 이상에 포함된 태스크는 경량의 Quartz라고 할 수 있으며, 나중에 소개할 Quartz에 비해 사용이 훨씬 간편하다.
1. Job 클래스는 특정 Job 클래스 기본 클래스에서 상속해야 합니다. 예를 들어 Quartz는 org.springframework.scheduling에서 상속해야 합니다. .quartz.QuartzJobBean ; java.util.Timer는 java.util.TimerTask에서 상속해야 합니다.
2. 작업 클래스는 일반 Java 클래스이므로 기본 클래스에서 상속할 필요가 없습니다.
참고: 저는 개인적으로 두 번째 방법을 사용하는 것을 권장합니다. 모든 클래스가 공통 클래스이고 미리 다르게 취급할 필요가 없기 때문입니다.
1 지정된 시간마다 해당 트리거는 org.springframework입니다. .scheduling.quartz.SimpleTriggerBean
2. 지정된 시간마다 한 번씩 트리거됩니다. Quartz의 해당 스케줄러는 org.springframework.scheduling.quartz.CronTriggerBean
참고: 모든 작업이 그렇지는 않습니다. 두 트리거를 모두 사용할 수 있습니다. 예를 들어 java.util.TimerTask 작업은 첫 번째 작업만 사용할 수 있습니다. Quartz와 Spring 작업 모두 이 두 가지 트리거 조건을 지원할 수 있습니다.
쿼츠, 스프링 작업 등 각 작업 스케줄링 도구의 사용법을 자세히 소개합니다.
1단계: 작업 클래스 정의
import org.quartz.JobExecutionContext; import org.quartz.JobExecutionException; import org.springframework.scheduling.quartz.QuartzJobBean; public class Job1 extends QuartzJobBean { private int timeout; private static int i = 0; //调度工厂实例化后,经过timeout时间开始执行调度 public void setTimeout(int timeout) { this.timeout = timeout; } /** * 要调度的具体任务 */ @Override protected void executeInternal(JobExecutionContext context) throws JobExecutionException { System.out.println("定时任务执行中…"); } }
2단계: 스프링 구성 파일에서 작업 클래스 JobDetailBean 구성
<bean name="job1" class="org.springframework.scheduling.quartz.JobDetailBean"> <property name="jobClass" value="com.gy.Job1" /> <property name="jobDataAsMap"> <map> <entry key="timeout" value="0" /> </map> </property> </bean>
설명: org.springframework.scheduling.quartz.JobDetailBean에는 jobClass라는 두 가지 속성이 있습니다. 속성은 Java 코드에서 정의한 태스크 클래스이고, jobDataAsMap 속성은 태스크 클래스에 주입해야 하는 속성 값입니다.
3단계: 작업 예약의 트리거 방법(트리거) 구성
Quartz에는 두 가지 작업 트리거, 즉
org.springframework.scheduling.quartz.SimpleTriggerBean
org.springframework.scheduling이 있습니다. 첫 번째 SimpleTriggerBean은 30분마다 한 번씩 실행되는 등 특정 빈도의 작업 호출만 지원합니다.
구성 방법은 다음과 같습니다.
<bean id="simpleTrigger" class="org.springframework.scheduling.quartz.SimpleTriggerBean"> <property name="jobDetail" ref="job1" /> <property name="startDelay" value="0" /><!-- 调度工厂实例化后,经过0秒开始执行调度 --> <property name="repeatInterval" value="2000" /><!-- 每2秒调度一次 --> </bean>
두 번째 CronTriggerBean은 매일 12시와 같이 지정된 시간에 한 번 실행을 지원합니다.
<bean id="cronTrigger" class="org.springframework.scheduling.quartz.CronTriggerBean"> <property name="jobDetail" ref="job1" /> <!—每天12:00运行一次 --> <property name="cronExpression" value="0 0 12 * * ?" /> </bean>
cronExpression 표현식의 구문은 부록을 참조하세요.
4단계: 예약 팩토리 구성<bean class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
<property name="triggers">
<list>
<ref bean="cronTrigger" />
</list>
</property>
</bean>
둘째, Job 클래스는 특정 기본 클래스를 상속받지 않습니다. (권장)
org.springframework.scheduling.timer.MethodInvokingTimerTaskFactoryBean
org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean
이 두 클래스는 각각 spring에 해당합니다. 2개 지원 작업 스케줄링을 구현하는 방법으로는 위에서 언급한 Java와 함께 제공되는 타이머 작업 메서드와 Quartz 메서드가 있습니다. 여기서는 MethodInvokingJobDetailFactoryBean의 사용법에 대해서만 씁니다. 이 클래스를 사용하면 작업 클래스가 더 이상 어떤 클래스에서도 상속할 필요가 없고 일반적인 pojo라는 이점이 있습니다.
1단계: 태스크 클래스 작성 public class Job2 {
public void doJob2() {
System.out.println("不继承QuartzJobBean方式-调度进行中...");
}
}
说明:这一步是关键步骤,声明一个MethodInvokingJobDetailFactoryBean,有两个关键属性:targetObject指定任务类,targetMethod指定运行的方法。往下的步骤就与方法一相同了,为了完整,同样贴出。 第三步:配置作业调度的触发方式(触发器) Quartz的作业触发器有两种,分别是 org.springframework.scheduling.quartz.SimpleTriggerBean org.springframework.scheduling.quartz.CronTriggerBean 第一种SimpleTriggerBean,只支持按照一定频度调用任务,如每隔30分钟运行一次。 配置方式如下: 第二种CronTriggerBean,支持到指定时间运行一次,如每天12:00运行一次等。 以上两种方式根据实际情况任选一种即可 第四步:配置调度工厂 说明:该参数指定的就是之前配置的触发器的名字。 第五步:启动你的应用即可,即将工程部署至tomcat或其他容器。 到此,spring中Quartz的基本配置就介绍完了,当然了,使用之前,要导入相应的spring的包与Quartz的包,这些就不消多说了。 其实可以看出Quartz的配置看上去还是挺复杂的,没有办法,因为Quartz其实是个重量级的工具,如果我们只是想简单的执行几个简单的定时任务,有没有更简单的工具,有! 上节介绍了在Spring 中使用Quartz,本文介绍Spring3.0以后自主开发的定时任务工具,spring task,可以将它比作一个轻量级的Quartz,而且使用起来很简单,除spring相关的包外不需要额外的包,而且支持注解和配置文件两种 形式,下面将分别介绍这两种方式。 第一步:编写作业类 即普通的pojo,如下: 第二步:在spring配置文件头中添加命名空间及描述 第三步:spring配置文件中设置具体的任务 说明:ref参数指定的即任务类,method指定的即需要运行的方法,cron及cronExpression表达式,具体写法这里不介绍了,详情见上篇文章附录。 到这里配置就完成了,是不是很简单。 也许我们不想每写一个任务类还要在xml文件中配置下,我们可以使用注解@Scheduled,我们看看源文件中该注解的定义: 可以看出该注解有三个方法或者叫参数,分别表示的意思是: 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 第二步:添加task相关的配置: 说明:理论上只需要加上 Ok配置完毕,当然spring task还有很多参数,我就不一一解释了,具体参考xsd文档http://www.springframework.org/schema/task/spring-task-3.0.xsd。 更多编程相关知识,请访问:编程视频!! 위 내용은 Java에서 예약된 작업을 구현하는 여러 가지 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!<bean id="job2"
class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
<property name="targetObject">
<bean class="com.gy.Job2" />
</property>
<property name="targetMethod" value="doJob2" />
<property name="concurrent" value="false" /><!-- 作业不并发调度 -->
</bean>
<bean id="simpleTrigger" class="org.springframework.scheduling.quartz.SimpleTriggerBean">
<property name="jobDetail" ref="job2" />
<property name="startDelay" value="0" /><!-- 调度工厂实例化后,经过0秒开始执行调度 -->
<property name="repeatInterval" value="2000" /><!-- 每2秒调度一次 -->
</bean>
<bean id="cronTrigger" class="org.springframework.scheduling.quartz.CronTriggerBean">
<property name="jobDetail" ref="job2" />
<!—每天12:00运行一次 -->
<property name="cronExpression" value="0 0 12 * * ?" />
</bean>
<bean class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
<property name="triggers">
<list>
<ref bean="cronTrigger" />
</list>
</property>
</bean>
Spring-Task
第一种:配置文件方式
import org.springframework.stereotype.Service;
@Service
public class TaskJob {
5 public void job1() {
System.out.println(“任务进行中。。。”);
}
}
<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">
<task:scheduled-tasks>
<task:scheduled ref="taskJob" method="job1" cron="0 * * * * ?"/>
</task:scheduled-tasks>
<context:component-scan base-package=" com.gy.mytask " />
第二种:使用注解形式
@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();
}
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(“任务进行中。。。”);
}
}
<?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"/>