SpringBoot整合阿里云SchedulerX分布式任务调度组件

更多SpringBoot轮子导航

SpringBoot项目实现日志打印SQL明细(包括SQL语句和参数)几种方式
SpringBoot中几种好用的代码生成器(基于Mybatis-plus生成entity、mapper、xml等)
SpringBoot整合Groovy脚本,实现动态编程
SpringBoot整合ip2region实现使用ip监控用户访问城市
SpringBoot整合EasyExcel实现Excel表格的导出功能
SpringBoot整合阿里云OSS,支持文件上传、下载、删除、加签等操作
SpringBoot整合aspectj实现面向切面编程(即AOP)
SpringBoot整合Swagger2实现接口文档
SpringBoot整合阿里云SchedulerX分布式任务调度组件
SpringBoot整合kaptcha实现图片验证码功能

介绍一下🍬

官网文档地址:官网地址

分布式任务调度SchedulerX 2.0是阿里巴巴基于Akka架构自研的新一代分布式任务调度平台。兼容开源XXL-JOB、ElasticJob,支持Cron定时、一次性任务、任务编排、分布式执行批量任务等功能,具备高可用、可视化、可运维、低延时等能力。

说的简单点,SchedulerX是一个做定时任务的好工具

接入流程🍇

1、购买服务

如果只买基础版,一般任务都不会超过10000个,一年下来36.5元,其实还挺便宜的。

在这里插入图片描述

2、创建资源

官方文档:官方文档

在这里插入图片描述

2.1 创建命名空间

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
创建完之后会得到一个命名空间ID,这个ID将会作为application.yml的一个配置参数

2.2 创建应用

在这里插入图片描述
这里有两个参数也会作为application.yml的配置参数:应用ID和应用key

3、搭建项目

3.1 配置文件

SpringBoot项目pom.xml文件
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.7.1</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.example</groupId>
    <artifactId>SpringBoot-schedulerx</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>SpringBoot-schedulerx</name>
    <description>Demo project for Spring Boot</description>
    <properties>
        <java.version>1.8</java.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>com.aliyun.schedulerx</groupId>
            <artifactId>schedulerx2-spring-boot-starter</artifactId>
            <version>1.6.0</version>
            <!--如果用的是logback,需要把log4j和log4j2排除掉 -->
            <exclusions>
                <exclusion>
                    <groupId>org.apache.logging.log4j</groupId>
                    <artifactId>log4j-api</artifactId>
                </exclusion>
                <exclusion>
                    <groupId>org.apache.logging.log4j</groupId>
                    <artifactId>log4j-core</artifactId>
                </exclusion>
                <exclusion>
                    <groupId>log4j</groupId>
                    <artifactId>log4j</artifactId>
                </exclusion>
            </exclusions>
        </dependency>


        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

</project>

SpringBoot项目application.properties

这里需要提醒大家,如果在测试阶段,配置endpoint时候直接配置公网的链接就行了,因为有地域的endpoint都是生产环境,是连接不通的,项目启动会失败!!!

spring.schedulerx2.endpoint=acm.aliyun.com
spring.schedulerx2.namespace=xxx-xxx-xxx-xxx
spring.schedulerx2.groupId=open_net_test_group
# 1.2.1及以上版本设置appKey
spring.schedulerx2.appKey=xxxxxxxx

# 1.2.1以下版本设置AK/SK
#spring.schedulerx2.aliyunAccessKey=${aliyunAccessKey}
#spring.schedulerx2.aliyunSecretKey=${aliyunSecretKey}

3.2 项目代码

项目结构

在这里插入图片描述

SpringBootSchedulerxApplication.java
package com.example.springbootschedulerx;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class SpringBootSchedulerxApplication {

    public static void main(String[] args) {
        SpringApplication.run(SpringBootSchedulerxApplication.class, args);
    }

}

TestJob.java
package com.example.springbootschedulerx.job;

import com.alibaba.schedulerx.worker.domain.JobContext;
import com.alibaba.schedulerx.worker.processor.JavaProcessor;
import com.alibaba.schedulerx.worker.processor.ProcessResult;
import org.springframework.stereotype.Component;

@Component
public class TestJob extends JavaProcessor {

    @Override
    public ProcessResult process(JobContext context) throws Exception {
        System.out.println("调用成功");
        return new ProcessResult(true);
    }
}

4、配置任务

写完任务处理逻辑后,需要到SchedulerX平台上注册该任务,流程如下:

4.1 创建任务

首先,选择任务类型为java
其次,输入任务处理类的完整包路径
最后,单机运行表示不管你有多少台服务注册了同一个任务,也只会执行一次;而广播运行则表示全部都会执行

在这里插入图片描述

4.2 设置定时

在这里插入图片描述

4.3 设置报警配置

在这里插入图片描述

4.4 任务列表和记录

在这里插入图片描述

在这里插入图片描述

4.5 运行展示

在这里插入图片描述

  • 0
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论
以下是一个基于 xxl-job 实现 Spring Boot 分布式任务调度的示例代码: 1. 添加依赖 在 pom.xml 文件中添加以下依赖: ``` <dependency> <groupId>com.xuxueli</groupId> <artifactId>xxl-job-core</artifactId> <version>${xxl.job.version}</version> </dependency> ``` 2. 配置文件 在 application.properties 文件中添加以下配置: ``` xxl.job.admin.address=http://your_admin_address xxl.job.executor.appname=your_app_name xxl.job.executor.address=your_exec_address xxl.job.executor.ip= xxl.job.executor.port=9999 xxl.job.accessToken= ``` 其中,`xxl.job.admin.address` 为 xxl-job-admin 的地址,`xxl.job.executor.appname` 为应用名称,`xxl.job.executor.address` 为应用地址,`xxl.job.executor.ip` 为应用 IP 地址(可选),`xxl.job.executor.port` 为应用端口,`xxl.job.accessToken` 为访问令牌(可选)。 3. 创建任务 创建一个继承 `IJobHandler` 接口的任务类,如下所示: ``` @JobHandler(value="demoJobHandler") @Component public class DemoJobHandler extends IJobHandler { @Override public ReturnT<String> execute(String param) throws Exception { // 执行任务逻辑 return ReturnT.SUCCESS; } } ``` 其中,`@JobHandler` 注解指定任务名称,`execute` 方法为任务执行逻辑。 4. 注册任务 在 Spring Boot 启动类中注册任务,如下所示: ``` @SpringBootApplication public class Application { public static void main(String[] args) { // 启动任务调度器 XxlJobExecutor executor = new XxlJobExecutor(); executor.setAdminAddresses("http://your_admin_address"); executor.setAppName("your_app_name"); executor.setIp(""); executor.setPort(9999); executor.start(); SpringApplication.run(Application.class, args); } } ``` 其中,`XxlJobExecutor` 类为 xxl-job 的任务调度器,通过 `setAdminAddresses` 方法设置 xxl-job-admin 的地址,通过 `setAppName` 方法设置应用名称,通过 `setIp` 方法设置应用 IP 地址(可选),通过 `setPort` 方法设置应用端口,通过 `start` 方法启动任务调度器。 5. 配置任务 在 xxl-job-admin 管理界面中配置任务,指定任务名称、任务组、任务描述、任务执行器、执行参数、调度方式等信息。 6. 运行任务 在 xxl-job-admin 管理界面中启动任务,任务会被调度器自动执行。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

sum墨

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值