xxl-Job基础配置

介绍:

XXL-JOB是一个轻量级分布式任务调度平台,其核心设计目标是开发迅速、学习简单、轻量级、易扩展。现已开放源代码并接入多家公司线上产品线,开箱即用。

几个特性:

1、简单:支持通过Web页面对任务进行CRUD操作,操作简单,一分钟上手;
2、动态:支持动态修改任务状态、启动/停止任务,以及终止运行中任务,即时生效
3、注册中心: 执行器会周期性自动注册任务, 调度中心将会自动发现注册的任务并触发执行,每30秒清理一次注册表中的无效机器。同时,也支持手动录入执行器地址;
4 、失败处理策略:每10秒检测失败任务,报警和重试;
5、一致性:“调度中心”通过DB锁保证集群分布式调度的一致性, 一次任务调度只会触发一次执行

简单的job配置以及代码编写:

①.编写一个定时任务对象

在这里插入图片描述

1.在类上加上注解@JobHandler(value = “这个相当于这个定时任务的code唯一标识”)

2.该类要继承IJobHandler接口,实现execute()方法进行重写

3.在execute方法肿编写你需要处理的业务代码请求即可!

4.加上@Component注解在容器启动的时候将这个类注入到容器中

②去job的web页面配置任务参数

在这里插入图片描述

1.配置执行器

​ 1.AppName是在服务的配置文件自定义的任务调度名称,要跟配置文件定义的名称一致地址才能映射上

​ 2.Name自定义名称,排序默认1即可

​ 3.注册方式选择手动注册,机器地址的话就需要重启之后任务调度中心根据你定义的AppName去服务配置文件映射 找到名称一样的服务地址

在这里插入图片描述

配置文件里面的任务调度配置要开启:enable=true,创建好执行器之后重启服务就可自动映射上去啦!

2.任务管理配置

在这里插入图片描述

1.选择对应的绑定的执行器,然后新建任务

在这里插入图片描述

1.路由策略:

  1. 策略参数值详细含义
    第一个FIRST固定选择第一个机器
    最后一个LAST固定选择最后一个机器
    轮询ROUND依次选择执行
    随机RANDOM随机选择在线的机器
    一致性HASHCONSISTENT_HASH每个人物按照Hash算法固定选择某一台机器,且所有任务均匀散列在不同机器上
    最不经常使用LEAST_FREQUENTLY_USED使用频率最低的机器优先被选择
    最近最久未使用LEAST_RECENTLY_USED最久未使用的机器优先被选择
    故障转义FAILOVER按照顺序依次进行心跳检测,第一个心跳检测成功的机器选定为目标执行器并发起调度
    忙碌转义BUSYOVER按照顺序依次进行空闲检测,第一个空闲检测成功的机器选定位目标执行器并发起调度
    分片广播SHARDING_BROADCAST广播触发对应集群中所有机器执行一次任务,同事系统自动传递分片参数,可根据分片参数开发分片任务

2.任务描述:
自定义描述内容

3.Cron表达式:
这个参数表示你要多久,什么时候去调用这个任务,调用时间可根据需求自定义

4.JobHandler:
这个参数就是代码里面定义的任务唯一标识

5.任务参数:
传递给后台代码的参数值

6.子任务ID:

当有任务需要相互依赖时使用,比如在对账业务里,下载对账文件任务成功之后,才开始对账。那么,可以把这几个任务当成一个大任务来串行处理,即在一个任务的末尾触发另一个任务。

如果我们需要在本任务执行结束并且执行成功的时候触发另外一个任务,那么就可以把另外的任务作为本任务的子任务运行,就只需要在本任务里填入另外一个任务的jobId即可(可以在任务列表查看JobId)

7.阻塞处理策略:

策略参数值含义
单机串行,默认SERIAL_EXECUTION调度请求进入单机执行器后,调度请求进入FIFO队列并以串行方式运行
丢弃后续调度DISCARD_LATER调度请求进入单机执行器后,发现执行器存在运行的调度任务,本次请求将会被丢弃并标记为失败
覆盖之前调度COVER_EARLY调度请求进入单机执行器后,发现执行器存在运行的调度任务,将会终止运行中的调度任务并清空队列,然后运行本次调度任务

可以手动调用任务进行执行:执行成功之后查看日志!!!

在这里插入图片描述

  • 23
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
# 简介 springboot-skeleton 是一个基于SpringBoot,快速构建微服务项目的脚手架。内置mybatis-plus、alibaba-druid、xxl-job、redis、rocketMq等基础组件,并且包括了这些基础组件的使用demo; 本项目master分支作为基础脚手架,包括大家平时常用的基础依赖包,非常用包例如分库分表、多数据源等场景会通过特色分支来建设 # 功能特点 - [x] 基于Eureka注册中心 - [x] swagger 接口文档生成 - [x] 基于xxl-job的分布式任务调度器 - [x] ORM代码自动生成 - [x] 参数优雅验证 - [x] druid数据库连接池; - [x] 连接池监控UI; - [x] sharding-jdbc 分库分表中间件 - [x] 链路追踪组件 - [x] 配置中心 - [x] 分布式锁 redission # 核心组件 - [x] Skywalking - [x] Swagger-Ui - [x] Mybatis-plus - [x] Druid - [x] Eureka - [x] Xxl-job - [x] Sharding-jdbc - [x] hutool - [x] Redis - [ ] Nacos - [ ] RocketMq - [ ] Easypoi - [ ] OSS # 使用方式 待完善 ## 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值