[xuxueli/xxl-job]偶发性 job execute timeout

2023-12-14 601 views
4
Which version of XXL-JOB do you using?

2.3.0

Expected behavior

handler.execute();输出耗时日志,

Actual behavior

业务日志未输出,taskJobHandler内未有日志输出 执行超时 job execute timeout

Steps to reproduce the behavior

重现困难,目前配置单机,任务181条,每个任务每秒执行一次,超时设置1s

Other information

超时源码 `if (triggerParam.getExecutorTimeout() > 0) { Thread futureThread = null; try { FutureTask futureTask = new FutureTask(new Callable(){ @Override public Boolean call() throws Exception {

                                // init job context
                                XxlJobContext.setXxlJobContext(xxlJobContext);

                                handler.execute();
                                return true;
                            }
                        });
                        futureThread = new Thread(futureTask);
                        futureThread.start();

                        Boolean tempResult = futureTask.get(triggerParam.getExecutorTimeout(),
                                                     TimeUnit.SECONDS);
                    } catch (TimeoutException e) {

                        XxlJobHelper.log("<br>----------- xxl-job job execute timeout");
                        XxlJobHelper.log(e);

                        // handle result
                        XxlJobHelper.handleTimeout("job execute timeout ");
                    } finally {
                        futureThread.interrupt();
                    }`

` @XxlJob("taskJobHandler") public void taskJobHandler() throws Exception { String param = XxlJobHelper.getJobParam(); long logId = LogUtils.getLogId(); StrategyJobParams strategyJobParams = objectMapper.readValue(param, StrategyJobParams.class); //计算期望执行几次 int expectTime = strategyJobParams.getExpectTime();

    if (expectTime < minTime) {
        int num = minTime / expectTime;
        long start = System.currentTimeMillis();
        for (int i = 0; i < num; i++) {
            long startTime = System.currentTimeMillis();
            long totalTime = startTime - start;
            如果剩余时间小于期望执行时间,跳出
            log.info("logId:[{}],[{}],总耗时:{},  剩余时间{}",logId,strategyJobParams.getContract(), totalTime, (minTime - totalTime));
            if (expectTime > (minTime - totalTime)) {
                break;
            }
            try {
                doNearStrategy(strategyJobParams.getContract(),logId, strategyJobParams);
            } catch (Exception exception) {
                log.error("logId:[{}],[{}],{}:策略执行异常", logId,strategyJobParams.getContract(), exception);
            }

            Long spendTime = System.currentTimeMillis() - startTime;

            //计算当前时间范围还剩多少毫秒,大于0时做延时处理,保证任务均匀分布在这一秒内
            int delayTime = expectTime - spendTime.intValue() - 5;
            if (delayTime > 0) {
                Thread.sleep(delayTime);
            }
        }
    } else {

       log.info("策略执行")
        doNearStrategy(strategyJobParams.getContract(),logId, strategyJobParams);
    }
    XxlJobHelper.handleSuccess();
}`

回答

1

现场情况 3秒,三次调度日志 出现 job execute timeout ,但是没有log.info日志,看起来像未执行FutureTask 中的handler.execute(); 然而futureTask.get(triggerParam.getExecutorTimeout(), TimeUnit.SECONDS);抛出了TimeoutException

7

我遇到的是我的调度执行时长大于了我设置的超时时长,修改了超时时长就不报超时了