您好,欢迎访问一九零五行业门户网

如何使用Quartz实现Java高可用定时任务?

定时任务使用指南如果你想做定时任务,有高可用方面的需求,或者仅仅想入门快,上手简单,那么选用它准没错。
定时任务模块是对quartz框架进一步封装,使用更加简洁。
1、引入依赖<dependency> <groupid>xin.altitude.cms</groupid> <artifactid>ucode-cms-quartz</artifactid> <version>1.5.4.1</version></dependency>
2、快速上手实现org.quartz.job接口;使用注解cronexp添加任务的调度策略;使用注解component将任务注入容器中。
启动项目,定时任务便处于监听与运行中。
@component@disallowconcurrentexecution@cronexp(cron = "0/5 * * * * ?")public class demojob implements job { @override public void execute(jobexecutioncontext context) { system.out.println("任务1:" + localdatetime.now()); }}
3、手动触发定时任务定时任务除了以既有频率周期性运行外,还有通过接口手动被触发的能力。
调用如下接口,可手动触发任务id编号为jobid的任务。
http://localhost:8080/cms-api/quartz/job/{jobid}
如果有手动触发定时任务的需求,则需要任务id唯一并且已知,因此需要在编写定时任务时手动指定。
@cronexp(id = 1, cron = "0/5 * * * * ?")
通过注解cronexp的id属性可指定任务id,不显示指定则使用随机id,不满足已知的条件,因此无法手动触发。
4、带参数任务尽管大多数任务不需要注入参数,但仍有少量的场景需要向定时任务注入参数。
public void execute(jobexecutioncontext context) { /* 如果在调用任务时传入了参数,则能够从map中获取 */ map<string, object> datamap = context.getmergedjobdatamap(); /* 比如从map中获取一个键值对,一般来说参数均为基本数据类型 */ object key = datamap.get("key"); system.out.println("任务2:" + localdatetime.now() + ": " + key);}
在编写定时任务时,可从jobexecutioncontext对象中解析一个map,从而完成参数的注入。
http://localhost:8080/cms-api/quartz/job/1?key=a
上述http调用的含义是手动触发任务id为【1】的任务,并且向其传递参数为【key】值为【a】的参数。
5、任务并发本框架不支持任务并发,换句话说并发对定时任务不利,因此需要手动禁止。
需要注意的是quartz的并发是指当任务执行耗时超过任务调度周期时,上一个任务未执行完,新任务是否执行。
一般来说需要显示禁止并发,在任务类上添加注解disallowconcurrentexecution即可禁止任务并发。
6、持久化如果定时任务有高可用的需求,那么需要对任务进行持久化。定时任务数据持久化到数据库中后,支持应用程序多开。定时任务持久化多节点部署后,集群中单节点故障不影响定时任务的执行。
定时任务持久化,仅需修改yml文件配置即可达到目标,无需修改代码。一般而言使用mysql做持久化的容器。
spring: quartz: properties: org.quartz.jobstore.isclustered: true org.quartz.jobstore.class: org.quartz.impl.jdbcjobstore.jobstoretx org.quartz.jobstore.driverdelegateclass: org.quartz.impl.jdbcjobstore.stdjdbcdelegate org.quartz.jobstore.datasource: qzds org.quartz.datasource.qzds.driver: com.mysql.cj.jdbc.driver org.quartz.datasource.qzds.url: jdbc:mysql://localhost:3306/quartz-demo org.quartz.datasource.qzds.user: root org.quartz.datasource.qzds.password: 123456
除了修改主机、端口、数据库名、用户名、密码五个参数外,其余参数使用默认值即可。
配置完数据库连接后,使用sql脚本,注意初始化数据库
以上就是如何使用quartz实现java高可用定时任务?的详细内容。
其它类似信息

推荐信息