首页 > 其他分享 >SpringBoot项目接入分布式任务调度平台xxl-job(2.0.2)说明

SpringBoot项目接入分布式任务调度平台xxl-job(2.0.2)说明

时间:2024-05-30 17:21:39浏览次数:32  
标签:执行器 2.0 SpringBoot Value job xxlJobSpringExecutor import 任务调度 xxl

简介

如果是单体项目,定时任务写到项目中就能满足需要,当需要部署集群的时候就会出现问题,接入统一的任务调试平台是一个不错的选择。接入xxl-job挺简单的,只需要几步,好记性不如烂笔头,记录一下步骤,方便以后使用。

 

本次使用软件的相关版本:

xxl-job版本:2.0.2

spring-boot:2.3.6.RELEASE

 

操作步骤:

1、在需要接入项目的pom.xml中添加xxl-job的引用

<!--xxl-job-->
<dependency>
<groupId>com.xuxueli</groupId>
<artifactId>xxl-job-core</artifactId>
<version>2.0.2</version>
</dependency>

2、在application.yml中添加xxl-job相关配置

# XXL-JOB相关配置
xxl:
  job:
    accessToken:
    admin:
      addresses: http://192.168.110.180:8888/xxl-job-admin
    executor:
      appname: ai-data-mining-service
      address:
      ip:
      port: 9993
      logpath: ./log
      logretentiondays: 10

解释一下其中的名词

accessToken:是安全令牌,用于验证执行器(executor)和调度中心(admin)之间的通信,这里为空,意味着没有设置安全令牌;

addresses:是xxl-job调度中心的地址;

appname:是要接入的项目的执行器的名称,用于标识该执行器;

address:是执行器的地址,通常用于手动注册执行器,留空表示自动获取;

ip:执行器的 IP 地址,通常用于手动注册执行器的 IP 地址,留空表示自动获取;

port:执行器的端口号,用于执行器服务的监听端口;

logpath:日志存储路径,执行器运行的日志文件将存储在这个路径中;

logretentiondays:日志保留天数,表示日志文件的保留时间,单位为天。

 

3、在项目中添加配置类

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;

/**
 * XXL作业配置
 *
 * @author
 * @date
 */
@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(initMethod = "start", destroyMethod = "destroy")
    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;
    }
}

 4、实现xxl-job的IJobHandler接口

import com.xxl.job.core.biz.model.ReturnT;
import com.xxl.job.core.handler.IJobHandler;
import com.xxl.job.core.handler.annotation.JobHandler;
import com.xxl.job.core.log.XxlJobLogger;
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Component;

/**
 * @author
 * @date
 */
@JobHandler(value = "DmAiPromptWordsJob")
@Component
@RequiredArgsConstructor
@Slf4j
public class DmAiPromptWordsJobHandler extends IJobHandler {
    @Override
    public ReturnT<String> execute(String s) throws Exception {
        log.info("项目日志打印");
        XxlJobLogger.log("xxl-job日志打印");
        return ReturnT.SUCCESS;
    }
}

其中@JobHandler(value = "DmAiPromptWordsJob"),注解用来标识这个类是一个 xxl-job 的任务处理器

5、在xxl-job管理界面中新增执行器,如下图:

注册方式,选择“自动注册”

6、在对应的执行器中添加任务管理,如下图:

重点填写红色框的部分即可;

 

总结

按照步骤操作之后,定时任务就自动运行了,这样的话部项目署集群也不受影响了,目前xxl-job也存在集群的问题,后续再研究。

标签:执行器,2.0,SpringBoot,Value,job,xxlJobSpringExecutor,import,任务调度,xxl
From: https://www.cnblogs.com/zhuangge/p/18222825

相关文章

  • springboot基于Java的超市进销存系统vue(源码+lw+部署文档+讲解等)
    前言......
  • 基于springboot家政服务管理平台vue(源码+lw+部署文档+讲解等)
    前言......
  • Ubuntu22.04安装部署基于dockers的K8s目前最新版本1.30.1版本
    其实之前也写过其他系统、其他版本的部署,但是,由于在1.28版本之后,安装略有所变化,所以,这里再写一篇基础环境主机名配置角色系统版本IP安装的组件master4核4GmasterUbuntu22.04192.168.140.75apiserver、controller-manager、scheduler、kubelet、etcd、kube-pro......
  • SpringBoot整合Mybatis实现增删改查功能
    目录1.添加依赖2.配置数据源和MyBatis3.创建实体类4.Mapper接口与映射文件5.编写服务层6.控制器SpringBoot整合MyBatis是一个相对直接的过程,主要涉及添加依赖、配置数据源、配置MyBatis、创建实体类、Mapper接口和映射文件、以及编写服务层来实现增删改......
  • (小白专用)SpringBoot快速搭建
    SpringBoot简介跟优点SpringBoot是一个基于Spring框架的开源项目,用于简化和加速Spring应用程序的开发和部署过程。它通过提供默认配置和约定来简化Spring应用程序的搭建,从而让开发者更专注于编写业务逻辑而不是配置和设置。SpringBoot的主要特点包括:自动配置:Spr......
  • springboot~jpa审计字段的自动填充
    在使用SpringDataJPA中的@CreatedDate注解时,如果希望自动填充创建时间字段,通常需要结合@EntityListeners(AuditingEntityListener.class)注解一起使用。这是因为@CreatedDate等审计注解通常与审计事件监听器(AuditingEntityListener)一起工作,用于处理实体的审计信息。审......
  • 基于springboot+vue的家乡特色推荐系统
    开发语言:Java框架:springbootJDK版本:JDK1.8服务器:tomcat7数据库:mysql5.7(一定要5.7版本)数据库工具:Navicat11开发软件:eclipse/myeclipse/ideaMaven包:Maven3.3.9系统展示系统首页用户注册文章分享界面个人中心管理员登录管理员功能用户管理文章分类管理文章分享......
  • Java毕业设计-基于springboot开发的旅游网站-毕业论文(附毕设源代码)
    文章目录前言一、毕设成果演示(源代码在文末)二、毕设摘要展示1、开发说明2、需求/流程分析3、系统功能结构三、系统实现展示1、用户信息管理2、旅游动态管理3、景点信息管理4、公告信息管理四、毕设内容和源代码获取总结Java毕业设计-基于springboot开发的旅游网站-......
  • Springboot报class path resource [xxxxx.json] cannot be resolved to URL because i
    当Springboot解析resources文件下的json文件时,在本地环境好用,部署到服务器上找不到文件内容报错classpathresource[xxxxx.json]cannotberesolvedtoURLbecauseitdosenotexist问题排查(1)pom.xml文件配置<build><resources><resource><d......
  • springboot3项目的搭建三(统一返回异常等)
    springboot3项目的搭建三(统一返回异常等) 一、统一返回(其实两部分,一个是返回错误码可枚举可类,另一个是返回的实体其中data是泛型)1.返回码:packagecom.qiqi.common.constants;publicenumReturnCode{SUCCESS(200,"操作成功"),NEED_LOGIN(401,"需要登录后操作......