如何将Spring Cloud Task发布Data Flow上执行?

1.什么是Spring Cloud Task?

Spring Cloud Task 是 Spring Cloud 生态系统中的一个项目,专门用于简化短生命周期微服务的开发。它提供了一种创建、运行和监控一次性任务的方式,这些任务通常是非持久性的,并在完成后终止。

Spring Cloud Task 的主要功能和用途包括:

  1. 简化任务开发:通过提供一组简单的注解和配置,开发者可以快速创建短生命周期的任务。

  2. 任务执行和管理:支持任务的启动、停止和重启,并可以与 Spring Batch 集成以处理复杂的批处理任务。

  3. 任务监控:提供任务执行的详细信息和状态报告,帮助开发者监控任务的执行情况。

  4. 与Spring生态系统集成:可以无缝集成到Spring Boot应用中,并与Spring Cloud Data Flow等其他Spring项目协同工作,以实现更复杂的任务编排和数据流处理。

Spring Cloud Task 非常适合用于需要在云环境中执行的短期任务,如数据迁移、批处理作业、文件处理等。

2.开发一个简单的任务

pom.xml

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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <parent>
        <artifactId>springcloud-demo</artifactId>
        <groupId>com.et</groupId>
        <version>1.0-SNAPSHOT</version>
    </parent>
    <modelVersion>4.0.0</modelVersion>

    <artifactId>spring-loud-task</artifactId>

    <properties>
        <maven.compiler.source>17</maven.compiler.source>
        <maven.compiler.target>17</maven.compiler.target>
    </properties>
    <dependencies>
        <!-- Spring Boot Starter for Batch processing -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-batch</artifactId>
        </dependency>

        <!-- Spring Cloud Task -->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-task</artifactId>
        </dependency>

        <!-- Optional: Spring Boot Starter for Logging -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-logging</artifactId>
        </dependency>

        <!-- Optional: Spring Boot Starter for Testing -->
        <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>
                <version>3.3.4</version>
                <configuration>
                    <mainClass>com.et.MyTask</mainClass> 
                </configuration>

            </plugin>
        </plugins>
    </build>
</project>

task

java 复制代码
package com.et;

import org.springframework.boot.CommandLineRunner;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.autoconfigure.batch.BatchAutoConfiguration;
import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration;
import org.springframework.cloud.task.configuration.EnableTask;

@EnableTask
@SpringBootApplication(exclude = {DataSourceAutoConfiguration.class, BatchAutoConfiguration.class})
public class MyTask implements CommandLineRunner {

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

    @Override
    public void run(String... args) throws Exception {
        // some code
        System.out.println("Executing custom task...");
        // add your logic
    }
}

以上只是一些关键代码,所有代码请参见下面代码仓库

代码仓库

3.注册到Spring Cloud Data Flow

打包jar

复制代码
mvn install

上传某个地方,让data flow能下载到,比如 www.liuhaihua.cn/spring-loud...](p6-xtjj-sign.byteimg.com/tos-cn-i-73...)](www.liuhaihua.cn/wp-content/...%25E6%25B3%25A8%25E5%2586%258C%25E5%2588%25B0data "https://www.liuhaihua.cn/wp-content/uploads/2024/11/app.png)%E6%B3%A8%E5%86%8C%E5%88%B0data") flow,类型选task

4.创建一个任务实例并运行

选择之前注册的task,创建dataflow上的任务实例启动任务

5.查看日志

相关推荐
sp421 分钟前
动手写一个 Java JWT Token 生成组件
后端
未来影子2 分钟前
Spring Ai Alibaba Graph源码解读系列—action
后端
写bug写bug2 分钟前
搞懂MyBatis拦截器的工作原理
java·后端·mybatis
bobz9654 分钟前
windows MCP 架构
后端
dylan_QAQ5 分钟前
【附录】Spring容器启动流程详解 - prepareRefresh()方法分析
后端·spring
Seven9710 分钟前
剑指offer-21、栈的压⼊、弹出序列
java
一只叫煤球的猫10 分钟前
讲讲ResponseEntity的前世今生和水土不服
java·后端·spring
dylan_QAQ13 分钟前
【附录】Spring容器启动流程详解 - obtainFreshBeanFactory()方法分析
后端·spring
架构师沉默14 分钟前
MyBatis 四大组件深度剖析:从原理到实战
java·后端·架构
侧耳倾听11114 分钟前
Java的异常机制
java·开发语言