Spring Cloud 2.x系列之springboot集成quartz
在做项目时有时候会有定时器任务的功能,比如某某时间应该做什么,多少秒应该怎么样之类的。定时任务常用的业务场景是进行数据统计。spring支持多种定时任务的实现,今天介绍一下spring定时器和quartz定时器的使用。
一、spring定时器
spring自带支持定时器的任务实现。其可通过简单配置来实现定时任务。主要用到如下两注解:
@EnableScheduling:标注启动定时任务
@Scheduled:定义某个定时任务
常用说明:
@Scheduled(fixedRate=2000):上一次开始执行时间点后2秒再次执行
@Scheduled(fixedDelay=2000):上一次执行完毕时间点后2秒再次执行
@Scheduled(initialDelay=1000,fixedDelay=2000):第一次延迟1秒执行,然后在上一次执行完毕时间点后2秒再次执行
@Scheduled(cron="** * * * ?"):按cron规则执行
二、quartz定时任务
quzrtz主要理解如下几个概念:
Job:是一个接口,只有一个方法void execute(JobExecutionContext context),开发者实现该接口定义运行任务,JobExecutionContext类提供了调度上下文的各种信息。Job运行时的信息保存在JobDataMap实例中。
JobDetail:Quartz在每次执行Job时,都重新创建一个Job实例,所以它不直接接受一个Job的实例,相反它接收一个Job实现类,以便运行时通过newInstance()的反射机制实例化Job。因此需要通过一个类来描述Job的实现类及其它相关的静态信息,如Job名字、描述、关联监听器等信息,JobDetail承担了这一角色。
Trigger:是一个类,描述触发Job执行的时间触发规则。主要有SimpleTrigger和CronTrigger这两个子类。当仅需触发一次或者以固定时间间隔周期执行,SimpleTrigger是最适合的选择;而CronTrigger则可以通过Cron表达式定义出各种复杂时间规则的调度方案:如每凌晨1:00执行,周一、周三、周五下午5:00执行等;
Calendar:org.quartz.Calendar和java.util.Calendar不同,它是一些日历特定时间点的集合(可以简单地将org.quartz.Calendar看作java.util.Calendar的集合——java.util.Calendar代表一个日历时间点,无特殊说明后面的Calendar即指org.quartz.Calendar)。一个Trigger可以和多个Calendar关联,以便排除或包含某些时间点。假设,我们安排每周星期一早上10:00执行任务,但是如果碰到法定的节日,任务则不执行,这时就需要在Trigger触发机制的基础上使用Calendar进行定点排除。
Scheduler:代表一个Quartz的独立运行容器,Trigger和JobDetail可以注册到Scheduler中,两者在Scheduler中拥有各自的组及名称,组及名称是Scheduler查找定位容器中某一对象的依据,Trigger的组及名称必须唯一,JobDetail的组和名称也必须唯一(但可以和Trigger的组和名称相同,因为它们是不同类型的)。Scheduler定义了多个接口方法,允许外部通过组及名称访问和控制容器中Trigger和JobDetail。
1、新建项目,对应的pom.xml文件如下
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>spring-cloud</groupId> <artifactId>sc-scheduled</artifactId> <version>0.0.1-SNAPSHOT</version> <packaging>jar</packaging> <name>sc-scheduled</name> <url>http://maven.apache.org</url> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.0.4.RELEASE</version> </parent> <dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-dependencies</artifactId> <version>Finchley.RELEASE</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <maven.compiler.source>1.8</maven.compiler.source> <maven.compiler.target>1.8</maven.compiler.target> </properties> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!-- 集成quartz需要引入 --> <!--quartz相关依赖--> <!-- <dependency> <groupId>org.quartz-scheduler</groupId> <artifactId>quartz</artifactId> </dependency> <dependency> <groupId>org.quartz-scheduler</groupId> <artifactId>quartz-jobs</artifactId> </dependency>--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-quartz</artifactId> </dependency> </dependencies> </project>
2、新建sprinboot启动类ScheduledApplication.java
package sc.schedule; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.scheduling.annotation.EnableScheduling; @SpringBootApplication @EnableScheduling // 开启spring自带定时任务 publicclass ScheduledApplication { public static void main(String[] args) { SpringApplication.run(ScheduledApplication.class, args); } }
3、Spring定时任务类
packagesc.schedule.spring; import java.text.SimpleDateFormat; import java.util.Date; import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; @Component public class SpringScheduled { // 每1分钟执行一次 @Scheduled(cron = "0 */1 * ** * ") public void reportCurrentByCron() { System.out.println("Spring Scheduling Tasks: " + dateFormat().format(new Date())); } private SimpleDateFormat dateFormat() { returnnewSimpleDateFormat("HH:mm:ss"); } }
4、Quartz定时任务类
单任务模式:
package sc.schedule.quartz; import org.quartz.JobDetail; import org.quartz.Trigger; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.scheduling.quartz.CronTriggerFactoryBean; import org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean; importorg.springframework.scheduling.quartz.SchedulerFactoryBean; @Configuration publicclass QuartzScheduledOne { @Bean public ScheduledJobOne getScheduledJobOne(){ return new ScheduledJobOne(); } /** * 调度工厂 * *@param jobTrigger * 触发器 *@return */ @Bean(name = "scheduler") public SchedulerFactoryBean schedulerFactory(Trigger jobTrigger) { SchedulerFactoryBeanfactoryBean = new SchedulerFactoryBean(); // 用于quartz集群,QuartzScheduler 启动时更新己存在的Job factoryBean.setOverwriteExistingJobs(true); // 延时启动,应用启动1秒后 factoryBean.setStartupDelay(1); // 注册触发器 factoryBean.setTriggers(jobTrigger); return factoryBean; } /** * * 定时触发器 * *@param reptilianJob * 任务 * *@return * */ @Bean(name = "jobTrigger") public CronTriggerFactory BeancronJobTrigger(JobDetail jobDetail) { CronTriggerFactoryBean tigger = newCronTriggerFactoryBean(); tigger.setJobDetail(jobDetail); // cron表达式,每1分钟执行一次 tigger.setCronExpression("0/20 ** * * ?"); tigger.setName("jobTrigger"); return tigger; } /** * 配置任务 * *@param quartzTask * QuartzTask为需要执行的任务 *@return */ @Bean(name = "jobDetail") public MethodInvokingJobDetailFactory BeandetailFactoryBean(ScheduledJobOne quartzTask) { MethodInvokingJobDetailFactoryBeanjobDetail = new MethodInvokingJobDetailFactoryBean(); // 是否并发执行 jobDetail.setConcurrent(false); // 设置任务的名字 jobDetail.setName("jobDetail"); // 设置任务的分组,在多任务的时候使用 jobDetail.setGroup("jobDetailGroup"); // 需要执行的对象 jobDetail.setTargetObject(quartzTask); /* * TODO非常重要 执行QuartzTask类中的需要执行方法 */ jobDetail.setTargetMethod("execute"); return jobDetail; } }
任务模式参考源码
5、对应的类结构说明
6、启动ScheduledApplication类,并验证定时任务是否启动
(1) 注释QuartzScheduled类的Configuration注解
启动ScheduledApplication类查看日志:
(2) 放开QuartzScheduled类的Configuration注解,然后注释QuartzScheduled类的Configuration注解
启动ScheduledApplication类查看日志:
源码:
https://gitee.com/hjj520/spring-cloud-2.x/tree/master/sc-scheduled
本文作者:java乐园
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
自动装箱
自动装箱 这半年多的项目每天都挺忙的不停的讨论需求、写代码、该需求、改代码,每天都是业务逻辑,令人头大.这个月项目上线了准备看几本书深造下顺便写点博客,梳理下思路.原力在沸腾! 基本原理网上找的,解释的很详细 补充在使用自动装箱和拆箱需要注意 Long sum = 0L; for (long i = 0; i < Integer.MAX_VALUE; i++) { sum += 1; } System.out.println(sum); 这段程序算出的答案是正确的,但是比实际情况要更慢一些,只因为打错了一个字符.变量sum被声明为了Long而不是long,意味着程序构造了大约2^31个多余的Long实例(大约每次往Long sum中增加long时构造一个实例). 要优先使用基本类型而不是装箱基本类型,要当心无意识的自动装箱的
- 下一篇
Python3.7 contextvars 初探
简述 Python 3.7 于2018年6月27日发布,本篇文章将对其中新增模块contextvars 做初步介绍,为读者勾勒一个大概轮廓。 资料来源: Python 3.7 文档、源码。 1、contextvars是什么 2、类与方法 3、如何理解上下文 4、总结 一、contextvars是什么 这个模块提供了一组接口,可用于管理、储存、访问 局部上下文的状态。 主要用于在异步环境中管理上下文变量。 二、类与方法 1、ContextVar(name[, *, default]) 这个类用于表示一个上下文变量。 参数:name: 必要位参; 用于检验和Debug. default: 默参,且只能用keyword方式指定; 用于设定这个上下文变量的默认值。 属性:name:只读特性。 get([default]):返回该上下文变量的值。未指定默认值且上下文
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- CentOS8,CentOS7,CentOS6编译安装Redis5.0.7
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- Windows10,CentOS7,CentOS8安装Nodejs环境
- MySQL8.0.19开启GTID主从同步CentOS8
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- Windows10,CentOS7,CentOS8安装MongoDB4.0.16
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- CentOS7,8上快速安装Gitea,搭建Git服务器
- CentOS6,CentOS7官方镜像安装Oracle11G