分布式任务调度

本文介绍了分布式任务调度的概念,包括Quartz、Elastic-Job和XXL-JOB三种解决方案。Quartz是任务调度框架,Elastic-Job提供无中心化轻量级调度,而XXL-JOB则是一个轻量级分布式任务调度平台。每种框架的使用方法、工作原理和特点都进行了详细阐述,为企业在选择分布式任务调度方案时提供了参考。
摘要由CSDN通过智能技术生成

文章内容输出来源:拉勾教育Java高薪训练营

1.分布式任务调度介绍

分布式任务调度有两层含义:
(1)运行在分布式集群环境下的调度任务,即同一定时任务程序部署多份,只应该有一个定时任务执行;
(2)在分布式调度中,对比较大的定时任务进行分布式处理时,即把一个大的作业任务拆分为多个小的作业任务,同时执行,最终完成这个大的任务。

2.分布式任务调度解决方案

(1)基于Quartz开发任务管理平台
(2)分布式调度框架Elastic-Job
(3)分布式调度框架 XXL-JOB


(1)基于Quartz开发任务管理平台

Quartz是一个任务调度框架,使用时间表达式(包括:秒、分、时、日、周、年)来配置某一个任务什么时间去执行。Quartz的使用过程如下:
首先引入jar

<!--任务调度框架quartz-->
<!-- https://mvnrepository.com/artifact/org.quartz-scheduler/quartz -->
<dependency>
	<groupId>org.quartz-scheduler</groupId>
	<artifactId>quartz</artifactId>
	<version>2.3.2</version>
</dependency>

然后定义定时任务作业主调度程序

package quartz;
import org.quartz.*;
import org.quartz.impl.StdSchedulerFactory;
public class QuartzMain {
   
// 创建作业任务调度器
public static Scheduler createScheduler() throws SchedulerException {
   
	SchedulerFactory schedulerFactory = new StdSchedulerFactory();
	Scheduler scheduler = schedulerFactory.getScheduler();
	return scheduler;
}
// 创建一个作业任务
public static JobDetail createJob() {
   
	JobBuilder jobBuilder = JobBuilder.newJob(DemoJob.class);
	jobBuilder.withIdentity("jobName","myJob");
	JobDetail jobDetail = jobBuilder.build();
	return jobDetail;
}
/**
* 创建作业任务时间触发器
* cron表达式由七个位置组成,空格分隔
* 1、Seconds(秒) 0~59
* 2、Minutes(分) 0~59
* 3、Hours(小时) 0~23
* 4、Day of Month(天)1~31,注意有的月份不足31天
* 5、Month(月) 0~11,或者 JAN,FEB,MAR,APR,MAY,JUN,JUL,AUG,SEP,OCT,NOV,DEC
* 6、Day of Week(周) 1~7,1=SUN或者 SUN,MON,TUE,WEB,THU,FRI,SAT
* 7、Year(年)1970~2099 可选项
* 示例:
* 0 0 11 * * ? 每天的11点触发执行一次
* 0 30 10 1 * ? 每月1号上午10点半触发执行一次
*/
public static Trigger createTrigger() {
   
	// 创建时间触发器,按日历调度
	CronTrigger trigger = TriggerBuilder.newTrigger()
		.withIdentity("triggerName","myTrigger")
		.startNow()
		.withSchedule(CronScheduleBuilder.cronSchedule("0/2 * * * * ?"))
		.build();
	// 创建触发器,按简单隔离调度
	SimpleTrigger trigger1 = TriggerBuilder.newTrigger()
		.withIdentity("triggerName","myTrigger")
		.startNow()
		.withSchedule(SimpleScheduleBuilder
		.simpleSchedule()
		.withIntervalInSeconds(3)
		.repeatForever())
		.build();
	return trigger;
}
	// 定时任务作业主调度程序
	public static void main(String[] args) throws SchedulerException {
   
		// 创建一个作业任务调度器
		Scheduler scheduler = QuartzMain.createScheduler();
		// 创建一个作业任务
		JobDetail job = QuartzMain.createJob();
		// 创建一个作业任务时间触发器
		Trigger trigger = QuartzMain.createTrigger();
		// 使用调度器按照时间触发器执行这个作业任务
		scheduler.scheduleJob(job,trigger);
		scheduler.start();
	}
}

最后定义一个job,需实现Job接口

package quartz;
import org.quartz.Job;
import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;
public class DemoJob implements Job {
   
	public void execute(JobExecutionContext jobExecutionContext)
throws JobExecutionException {
   
		System.out.println(
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值