XXL-JOB分布式任务调度快速入门

2024-06-12 20:28

本文主要是介绍XXL-JOB分布式任务调度快速入门,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 概念
  • 快速启动XXL-JOB调度
  • 初始化执行器项目
  • 配置执行器
  • 新增GLUE模式(Java)的任务
  • 新增BEAN模式(类形式)的任务
  • BEAN模式(方法形式)的任务
  • 参考来源

概念

XXL-JOB是一个开源的分布式任务调度平台,它是一个轻量级、易扩展的任务调度平台

快速启动XXL-JOB调度

  • 拉取XXL-JOB源码

    git clone https://gitee.com/xuxueli0323/xxl-job.git
    
  • 执行调度数据库SQL脚本
    IDEA打开调度项目,执行doc/db/tables_xxl_job.sql

  • 配置调度中心数据库连接地址
    在这里插入图片描述

  • 修改调度中心日志文件地址
    在这里插入图片描述

  • 启动并访问调度中心

    • 访问地址:http://localhost:8080/xxl-job-admin
    • 用户名:admin
    • 密码:123456
      在这里插入图片描述

初始化执行器项目

  • 初始化一个Spring Boot项目

我这里使用的 Spring Boot 版本是 2.3.6.release
在这里插入图片描述

  • 引入maven依赖
    <dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!--   XXL-JOB 公共依赖   --><dependency><groupId>com.xuxueli</groupId><artifactId>xxl-job-core</artifactId><version>2.4.1</version></dependency></dependencies>
  • 配置 XXL-JOB
server.port=20200
spring.application.name=xxl-job-demo
### 调度中心部署根地址 [选填]:如调度中心集群部署存在多个地址则用逗号分隔。执行器将会使用该地址进行"执行器心跳注册"和"任务结果回调";为空则关闭自动注册;
xxl.job.admin.addresses=http://127.0.0.1:8080/xxl-job-admin
### 执行器通讯TOKEN [选填]:非空时启用;
xxl.job.accessToken=default_token
### 执行器AppName [选填]:执行器心跳注册分组依据;为空则关闭自动注册
xxl.job.executor.appname=my-xxl-job-executor
### 执行器注册 [选填]:优先使用该配置作为注册地址,为空时使用内嵌服务 ”IP:PORT“ 作为注册地址。从而更灵活的支持容器类型执行器动态IP和动态映射端口问题。
xxl.job.executor.address=
### 执行器IP [选填]:默认为空表示自动获取IP,多网卡时可手动设置指定IP,该IP不会绑定Host仅作为通讯实用;地址信息用于 "执行器注册" 和 "调度中心请求并触发任务";
xxl.job.executor.ip=
### 执行器端口号 [选填]:小于等于0则自动获取;默认端口为9999,单机部署多个执行器时,注意要配置不同执行器端口;
xxl.job.executor.port=9999
### 执行器运行日志文件存储磁盘路径 [选填] :需要对该路径拥有读写权限;为空则使用默认路径;
xxl.job.executor.logpath=D:\TestFiles\logs\xxl-job\jobhandler
### 执行器日志文件保存天数 [选填] : 过期日志自动清理, 限制值大于等于3时生效; 否则, 如-1, 关闭自动清理功能;
xxl.job.executor.logretentiondays=30
  • 创建XXL-JOB配置类
@Configuration
public class XxlJobConfig {private Logger logger = LoggerFactory.getLogger(XxlJobConfig.class);@Value("${xxl.job.admin.addresses}")private String adminAddresses;@Value("${xxl.job.accessToken}")private String accessToken;@Value("${xxl.job.executor.appname}")private String appname;@Value("${xxl.job.executor.address}")private String address;@Value("${xxl.job.executor.ip}")private String ip;@Value("${xxl.job.executor.port}")private int port;@Value("${xxl.job.executor.logpath}")private String logPath;@Value("${xxl.job.executor.logretentiondays}")private int logRetentionDays;@Beanpublic XxlJobSpringExecutor xxlJobExecutor() {logger.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;}
}
  • 启动项目

配置执行器

在这里插入图片描述

新增GLUE模式(Java)的任务

GLUE模式(Java)运行模式的任务实际上是一段继承自IJobHandler的Java类代码,它在执行器项目中运行,它只需要在调度中心控制台创建,无需我们手动编写任务代码

  • 创建GLUE模式(Java)的任务
    在这里插入图片描述
    在这里插入图片描述

  • 手动执行任务
    在这里插入图片描述
    在这里插入图片描述

  • 查看执行结果
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

实际上,当我们创建了一个GLUE模式(Java)的任务后,调度中心会帮我们自动生成任务代码,代码可以在GLUE IDE查看
在这里插入图片描述
在这里插入图片描述

新增BEAN模式(类形式)的任务

创建BEAN模式(类形式)的任务需要我们在执行器项目中自行编写任务代码

  • 创建一个Job类
public class MyXxlJob extends IJobHandler {@Overridepublic void execute() throws Exception {XxlJobHelper.log("hello class xxl-job");}
}
  • 在XXL-JOB配置类中将Job注入到执行器容器
    @PostConstructpublic void registerJob() {XxlJobExecutor.registJobHandler("MyXxlJob", new MyXxlJob());}
  • 创建BEAN模式(类形式)的任务
    在这里插入图片描述
  • 执行任务并查看执行结果
    与前面GLUE模式(Java)任务的操作类似

BEAN模式(方法形式)的任务

在BEAN模式(类形式)下,每个类代表一个任务,而在BEAN模式(方法形式)下,每个方法代表一个任务,只需要在方法上用@XxlJob注解标识即可

  • 创建一个Job类并编写一个Job方法
@Component
public class MyMethodXxlJob {@XxlJob("MyMethodXxlJob")public void sayHello() {XxlJobHelper.log("hello method xxl-job");}
}
  • 创建BEAN模式(方法形式)的任务
    在这里插入图片描述

  • 执行任务并查看执行结果
    与前面GLUE模式(Java)任务的操作类似

参考来源

  • XXL-JOB官网

这篇关于XXL-JOB分布式任务调度快速入门的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1055249

相关文章

一文详解如何在idea中快速搭建一个Spring Boot项目

《一文详解如何在idea中快速搭建一个SpringBoot项目》IntelliJIDEA作为Java开发者的‌首选IDE‌,深度集成SpringBoot支持,可一键生成项目骨架、智能配置依赖,这篇文... 目录前言1、创建项目名称2、勾选需要的依赖3、在setting中检查maven4、编写数据源5、开启热

Python中OpenCV与Matplotlib的图像操作入门指南

《Python中OpenCV与Matplotlib的图像操作入门指南》:本文主要介绍Python中OpenCV与Matplotlib的图像操作指南,本文通过实例代码给大家介绍的非常详细,对大家的学... 目录一、环境准备二、图像的基本操作1. 图像读取、显示与保存 使用OpenCV操作2. 像素级操作3.

MybatisX快速生成增删改查的方法示例

《MybatisX快速生成增删改查的方法示例》MybatisX是基于IDEA的MyBatis/MyBatis-Plus开发插件,本文主要介绍了MybatisX快速生成增删改查的方法示例,文中通过示例代... 目录1 安装2 基本功能2.1 XML跳转2.2 代码生成2.2.1 生成.xml中的sql语句头2

Golang实现Redis分布式锁(Lua脚本+可重入+自动续期)

《Golang实现Redis分布式锁(Lua脚本+可重入+自动续期)》本文主要介绍了Golang分布式锁实现,采用Redis+Lua脚本确保原子性,持可重入和自动续期,用于防止超卖及重复下单,具有一定... 目录1 概念应用场景分布式锁必备特性2 思路分析宕机与过期防止误删keyLua保证原子性可重入锁自动

8种快速易用的Python Matplotlib数据可视化方法汇总(附源码)

《8种快速易用的PythonMatplotlib数据可视化方法汇总(附源码)》你是否曾经面对一堆复杂的数据,却不知道如何让它们变得直观易懂?别慌,Python的Matplotlib库是你数据可视化的... 目录引言1. 折线图(Line Plot)——趋势分析2. 柱状图(Bar Chart)——对比分析3

一文教你Java如何快速构建项目骨架

《一文教你Java如何快速构建项目骨架》在Java项目开发过程中,构建项目骨架是一项繁琐但又基础重要的工作,Java领域有许多代码生成工具可以帮助我们快速完成这一任务,下面就跟随小编一起来了解下... 目录一、代码生成工具概述常用 Java 代码生成工具简介代码生成工具的优势二、使用 MyBATis Gen

基于MongoDB实现文件的分布式存储

《基于MongoDB实现文件的分布式存储》分布式文件存储的方案有很多,今天分享一个基于mongodb数据库来实现文件的存储,mongodb支持分布式部署,以此来实现文件的分布式存储,需要的朋友可以参考... 目录一、引言二、GridFS 原理剖析三、Spring Boot 集成 GridFS3.1 添加依赖

使用animation.css库快速实现CSS3旋转动画效果

《使用animation.css库快速实现CSS3旋转动画效果》随着Web技术的不断发展,动画效果已经成为了网页设计中不可或缺的一部分,本文将深入探讨animation.css的工作原理,如何使用以及... 目录1. css3动画技术简介2. animation.css库介绍2.1 animation.cs

SpringBoot快速搭建TCP服务端和客户端全过程

《SpringBoot快速搭建TCP服务端和客户端全过程》:本文主要介绍SpringBoot快速搭建TCP服务端和客户端全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录TCPServerTCPClient总结由于工作需要,研究了SpringBoot搭建TCP通信的过程

POI从入门到实战轻松完成EasyExcel使用及Excel导入导出功能

《POI从入门到实战轻松完成EasyExcel使用及Excel导入导出功能》ApachePOI是一个流行的Java库,用于处理MicrosoftOffice格式文件,提供丰富API来创建、读取和修改O... 目录前言:Apache POIEasyPoiEasyExcel一、EasyExcel1.1、核心特性