应用场景:
定时发送优惠券,定时更新大量数据场景放到redis缓存中,每隔几分钟执行的任务等等。
1.分为两块调度中心和执行器
我自己简单的理解:调度中心就是一个服务,启动之后可以进入它的任务调度中心的网页端。在网页端进行可视化操作,如添加执行器和任务,一个执行器可以有多个任务。
2.如何实现?
2.1先启动任务调度中心服务,可以本地也可以部署到远端
先拉取代码
xxl-job: 一个分布式任务调度平台,其核心设计目标是开发迅速、学习简单、轻量级、易扩展。现已开放源代码并接入多家公司线上产品线,开箱即用。
1.执行sql ,会生成几张表,因为xxl-job是基于mysql进行日志存储的
2.修改端口8080防止端口占用+修改数据库连接
3.启动xxl-job-admin这一个服务即可
4.启动成功之后直接访问调度中心的页面:把端口改成你自己的
地址:http://localhost:8080/xxl-job-admin/jobgroup
5.点击执行器,新增执行器
6.点击任务管理,添加一个任务
7.默认是停止状态,给它启动起来,也可以选择执行一次
8.在你自己的项目中创建执行器和需要执行的任务
配置application.yml文件,根据需求自己修改
xxl:
job:
admin:
addresses: http://localhost:8080/xxl-job-admin
accessToken: default_token
executor:
appname: daz-job
#ip: 10.123.1.53
port: 9999
# 日志地址
logpath: /data/applogs/xxl-job/jobhandler
# 日志保存时间
logretentiondays: 30
配置xxl-job的配置类XxlJobConfig,主要是为了配置XxlJobSpringExecutor执行器
package com.fzy.config;
import com.xxl.job.core.executor.impl.XxlJobSpringExecutor;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
@Configuration
@Slf4j
public class XxlJobConfig {
@Value("${xxl.job.admin.addresses}")
private String adminAddresses;
@Value("${xxl.job.executor.appname}")
private String appName;
/*@Value("${xxl.job.executor.ip}")
private String ip;*/
@Value("${xxl.job.executor.port}")
private int port;
@Value("${xxl.job.accessToken}")
private String accessToken;
@Value("${xxl.job.executor.logpath}")
private String logPath;
@Value("${xxl.job.executor.logretentiondays}")
private int logRetentionDays;
@Bean
public XxlJobSpringExecutor xxlJobExecutor() {
log.info(">>>>>>>>>>> xxl-job config init.");
XxlJobSpringExecutor xxlJobSpringExecutor = new XxlJobSpringExecutor();
xxlJobSpringExecutor.setAdminAddresses(adminAddresses);
xxlJobSpringExecutor.setAppname(appName);
//xxlJobSpringExecutor.setIp(ip);
xxlJobSpringExecutor.setPort(port);
xxlJobSpringExecutor.setAccessToken(accessToken);
xxlJobSpringExecutor.setLogPath(logPath);
xxlJobSpringExecutor.setLogRetentionDays(logRetentionDays);
return xxlJobSpringExecutor;
}
}
编写需要执行定时任务XxlDemoHandler,在方式上加上@XxlJob("Demo"),来作为定时执行的任务,参数就是我们在任务调度中心添加任务时JobHandler需要的参数
import com.xxl.job.core.biz.model.ReturnT;
import com.xxl.job.core.context.XxlJobHelper;
import com.xxl.job.core.handler.annotation.XxlJob;
import org.springframework.stereotype.Component;
@Component
public class XxlDemoHandler {
@XxlJob("Demo")
public ReturnT<String> demo(){
String param = XxlJobHelper.getJobParam();
XxlJobHelper.log("测试开始");
System.out.println(param);
System.out.println("测试完成!!!!!!!!!!!!!!!!!!!!!!!!!!!!");
XxlJobHelper.log("测试开结束");
return ReturnT.SUCCESS;
}
}
可以在任务调度中心控制任务的定时执行,可以运行或者停止,也可以修改cron表达式改成什么时间段去执行,Cron表达式简单学习