当前位置: 首页 > article >正文

xxljob阻塞处理策略设置为单机串行导致的bug

场景描述:

        之前我们公司有个项目需要每五分钟去拉取平台上的订单,于是乎我就在xxljob设置了这个定时任务,设置如下:

然后xxljob内的代码如下:

@XxlJob(value = "pullOrderTask")
    public ReturnT pullOrderTask(String param) {
                orderService.pullOrderTask();
        return ReturnT.SUCCESS;
    }

 错误描述:

        然后我发现有些订单没有拉取下来有遗漏,对运营工作造成了影响。

错误分析:

        我第一时间找到了没拉取下来的订单,看了一下定时任务打印的日志,发现定时任务执行有延迟,本来16:30以后还要再执行三次任务,但是日志中没有体现,16:30以后应该要执行的三次任务延迟到了16:52在执行。后来检查代码才发现执行pullOrderTask这个方法的时候,调用第三方平台的接口有限流,因此我设置了重试和延迟机制,这就导致有些任务在五分钟内并没有执行完毕。

         而我设置的阻塞策略是串行这就导致了,前面的任务没完成,后面的任务来的话只能进入阻塞队列,到前面的任务执行完毕之后再执行。

错误解决:

一、设置用多线程执行任务

        再看了xxljob的文档以后,我发现剩下的两个阻塞策略都无法解决我的问题,因此我引入了多线程用多线程执行定时任务,就不会发生上面的事情了,代码如下:

    @Resource(name = "threadPool")
    private ThreadPoolExecutor threadPool;



@XxlJob(value = "pullOrderTask")
public ReturnT pullOrderTask(String param) {
xingshaThreadPool.execute(()->{
  try {

              orderService.pullOrderTask();
      } catch (Throwable e) {
       log.error("定时拉取处方单多线程错误,入参为{},错误详情:{}", JSON.toJSONString(param),e);
            }
        });
               
        return ReturnT.SUCCESS;
}

二、设置兜底任务在夜间把昨天所有订单再拉取一遍

        除此之外我又设置了一个定时任务,凌晨1点拉取昨天的所有订单,以防上面的那个订单有遗漏。


http://www.kler.cn/a/611611.html

相关文章:

  • PyTorch 深度学习实战(22):多智能体强化学习(MARL)
  • 堆的常见应用2
  • 3.27【A】cv homework
  • 手撕LRU缓存Java版(带输入输出)
  • 《基于机器学习发电数据电量预测》开题报告
  • 学习本地部署DeepSeek的过程(基于LM Studio)
  • 自然语言处理|金融舆情解析:智能事件抽取与风险预警之道
  • 算法-动态规划三
  • 学习threejs,使用Sprite精灵、SpriteMaterial精灵材质
  • 企业内训|DeepSeek技术革命、算力范式重构与场景落地洞察-某头部券商
  • 精选10个好用的WordPress免费主题
  • ELK stack基础架构
  • Android TextView实现跑马灯效果性能优化
  • 用shell脚本,批量备份MySQL中所有数据库,并批量还原!
  • asp.net进销存软件WEB进销存ERP软件库存玻璃行业
  • SQLite优化实践
  • 【设计模式】策略模式(Strategy Pattern)详解
  • 5分钟快速上手Docker容器化部署:从零到实践
  • 带你刷题—公因子的数目(leetcode2427)
  • docker-操作实战