xxljob任务实例

本文详细介绍了XXL-JOB这个分布式任务调度平台的使用,包括简单模式、分片广播任务、命令行任务、跨平台HTTP任务和生命周期任务。通过示例代码展示了如何配置和执行各种任务,以及任务的初始化和销毁操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

代码来源于官网

1.简单模式

@XxlJob("demoJobHandler")
    public ReturnT<String>  demoJobHandler(String param) throws Exception {
        XxlJobHelper.log("XXL-JOB, Hello World.");

        for (int i = 0; i < 5; i++) {
            XxlJobHelper.log("beat at:" + i);
            TimeUnit.SECONDS.sleep(2);
        }
        // default success
        ReturnT<String> msg=new ReturnT<>(200,"[执行成功]"+new Date());
        return msg;
    }

调度中心admin的任务运行模式要和@XxlJob值一致

运行结果:

 2.分片广播任务

@XxlJob("shardingJobHandler")
    public void shardingJobHandler() throws Exception {

        // 分片参数
        int shardIndex = XxlJobHelper.getShardIndex();  //当前分片
        int shardTotal = XxlJobHelper.getShardTotal();  //总分片

        XxlJobHelper.log("分片参数:当前分片序号 = {}, 总分片数 = {}", shardIndex, shardTotal);

        // 业务逻辑
        for (int i = 0; i < shardTotal; i++) {
            if (i == shardIndex) {
                XxlJobHelper.log("第 {} 片, 命中分片开始处理", i);
            } else {
                XxlJobHelper.log("第 {} 片, 忽略", i);
            }
        }

    }

     1)单机多任务:配置多个任务,指定不同的参数,但是使用相同的jobHandler

     2)多机分片:启动多个执行器管理实例,配置一个分片任务

3.命令行任务

@XxlJob("commandJobHandler")
    public void commandJobHandler() throws Exception {
        String command = XxlJobHelper.getJobParam();
        int exitValue = -1;

        BufferedReader bufferedReader = null;
        try {
            // command process
            ProcessBuilder processBuilder = new ProcessBuilder();
            processBuilder.command(command);
            processBuilder.redirectErrorStream(true);

            Process process = processBuilder.start();
            //Process process = Runtime.getRuntime().exec(command);

            BufferedInputStream bufferedInputStream = new BufferedInputStream(process.getInputStream());
            bufferedReader = new BufferedReader(new InputStreamReader(bufferedInputStream));

            // command log
            String line;
            while ((line = bufferedReader.readLine()) != null) {
                XxlJobHelper.log(line);
            }

            // command exit
            process.waitFor();
            exitValue = process.exitValue();
        } catch (Exception e) {
            XxlJobHelper.log(e);
        } finally {
            if (bufferedReader != null) {
                bufferedReader.close();
            }
        }

        if (exitValue == 0) {
            // default success
        } else {
            XxlJobHelper.handleFail("command exit value("+exitValue+") is failed");
        }

    }

创建commandJobHandler,写一个bat或者cmd文件,任务运行时任务参数

D:/a.bat

bat文件:

@echo  off
start https://www.baidu.com/s?wd=xxljob

任务执行成功后自动跳转到相关网页:

4.跨平台http任务
@XxlJob("httpJobHandler")
    public void httpJobHandler() throws Exception {

        // param parse
        String param = XxlJobHelper.getJobParam();
        if (param==null || param.trim().length()==0) {
            XxlJobHelper.log("param["+ param +"] invalid.");

            XxlJobHelper.handleFail();
            return;
        }

        String[] httpParams = param.split("\n");
        String url =null;
        String method = null;
       // String data = null;   //null
        for (String httpParam: httpParams) {
            if (httpParam.startsWith("url:")) {
                url = httpParam.substring(httpParam.indexOf("url:") + 4).trim();
            }
            if (httpParam.startsWith("method:")) {
                method = httpParam.substring(httpParam.indexOf("method:") + 7).trim().toUpperCase();
            }
            /*if (httpParam.startsWith("data:")) {
                data = httpParam.substring(httpParam.indexOf("data:") + 5).trim();
            }*/
        }

        // param valid
        if (url==null || url.trim().length()==0) {
            XxlJobHelper.log("url["+ url +"] invalid.");

            XxlJobHelper.handleFail();
            return;
        }
        if (method==null || !Arrays.asList("GET", "POST").contains(method)) {
            XxlJobHelper.log("method["+ method +"] invalid.");

            XxlJobHelper.handleFail();
            return;
        }
        boolean isPostMethod = method.equals("POST");

        // request
        HttpURLConnection connection = null;
        BufferedReader bufferedReader = null;
        try {
            // connection
            URL realUrl = new URL(url);
            connection = (HttpURLConnection) realUrl.openConnection();

            // connection setting
            connection.setRequestMethod(method);
            connection.setDoOutput(isPostMethod);
            connection.setDoInput(true);
            connection.setUseCaches(false);
            connection.setReadTimeout(5 * 1000);
            connection.setConnectTimeout(3 * 1000);
            connection.setRequestProperty("connection", "Keep-Alive");
            connection.setRequestProperty("Content-Type", "application/json;charset=UTF-8");
            connection.setRequestProperty("Accept-Charset", "application/json;charset=UTF-8");

            // do connection
            connection.connect();

            // data
           /* if (isPostMethod && data!=null && data.trim().length()>0) {
                DataOutputStream dataOutputStream = new DataOutputStream(connection.getOutputStream());
                dataOutputStream.write(data.getBytes("UTF-8"));
                dataOutputStream.flush();
                dataOutputStream.close();
            }*/

            // valid StatusCode
            int statusCode = connection.getResponseCode();
            if (statusCode != 200) {
                throw new RuntimeException("Http Request StatusCode(" + statusCode + ") Invalid.");
            }

            // result
            bufferedReader = new BufferedReader(new InputStreamReader(connection.getInputStream(), "UTF-8"));
            StringBuilder result = new StringBuilder();
            String line;
            while ((line = bufferedReader.readLine()) != null) {
                result.append(line);
            }
            String responseMsg = result.toString();

            XxlJobHelper.log(responseMsg);

            return;
        } catch (Exception e) {
            XxlJobHelper.log(e);

            XxlJobHelper.handleFail();
            return;
        } finally {
            try {
                if (bufferedReader != null) {
                    bufferedReader.close();
                }
                if (connection != null) {
                    connection.disconnect();
                }
            } catch (Exception e2) {
                XxlJobHelper.log(e2);
            }
        }

    }

 任务参数

 执行成功后执行日志自动跳转

 

5.生命周期任务

@XxlJob(value = "demoJobHandler2", init = "init", destroy = "destroy")
    public void demoJobHandler2() throws Exception {
        XxlJobHelper.log("XXL-JOB, Hello World.");
    }
    public void init(){
        logger.info("init");
    }
    public void destroy(){
        logger.info("destory");
    }
任务初始化与销毁时,支持自定义相关逻辑;
### 如何在 XXL-Job 中主动终止任务实例 为了实现在 XXL-Job 中主动终止任务实例的功能,可以利用其提供的 API 接口来完成操作。具体来说,可以通过调用 `JobHandler` 的逻辑,在满足特定条件时手动触发任务中断机制。 #### 1. 使用 JobThread 实现线程管理 XXL-Job 提供了一个内置的任务执行器框架,其中每个任务都会被分配到独立的线程中运行。开发者可以在自定义的任务处理器类中通过获取当前线程对象并对其进行控制的方式实现任务的主动停止功能[^1]。 以下是基于 Spring Boot 集成环境下的代码示例: ```java import com.xxl.job.core.handler.annotation.XxlJob; import org.springframework.stereotype.Component; @Component public class MyJob { @XxlJob("myJobHandler") public void myJobHandler() throws InterruptedException { Thread currentThread = Thread.currentThread(); while (!currentThread.isInterrupted()) { // 判断线程是否已被标记为中断状态 System.out.println("Task is running..."); Thread.sleep(1000); // 模拟业务处理延迟 // 如果需要提前退出任务,则在此处设置标志位或者直接抛出异常 if (someConditionToStop()) { // 自定义停止条件判断方法 break; // 跳出循环从而结束任务 } } if (currentThread.isInterrupted()) { System.err.println("Task has been interrupted!"); } else { System.out.println("Task completed normally."); } } private boolean someConditionToStop() { // 定义具体的停止条件逻辑 return false; // 返回 true 表示应该立即停止该任务 } } ``` 上述代码片段展示了如何检测线程的状态以及依据外部信号决定何时让程序流程自然结束或强制跳出循环结构[^2]。 #### 2. 借助 Admin API 远程操控任务生命周期 除了修改本地代码外,还可以借助于官方文档提到过的 HTTP 请求接口对正在运行中的作业项发起取消请求。例如访问 URL `/jobinfo/stop/{id}` 可以尝试停止指定 ID 对应的任务实例[^2]。 注意:此方式适用于管理员权限场景下远程干预目标服务器上的进程行为;而对于某些特殊类型的长期运行型服务端应用而言可能并不适用,因为它们往往依赖更复杂的上下文切换机制才能安全地中止工作流而不会引发数据丢失等问题。 --- ### 总结 综上所述,无论是采用编程手段还是运维工具都可以有效地达成使某个既定计划内的活动提早告终的目的。对于前者主要涉及到了多线程技术的应用实践领域;后者则更多体现出了微服务体系架构设计原则下跨组件协作能力的重要性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值