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

场景描述:

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

然后xxljob内的代码如下:

java 复制代码
@XxlJob(value = "pullOrderTask")
    public ReturnT pullOrderTask(String param) {
                orderService.pullOrderTask();
        return ReturnT.SUCCESS;
    }

错误描述:

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

错误分析:

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

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

错误解决:

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

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

java 复制代码
    @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点拉取昨天的所有订单,以防上面的那个订单有遗漏。

相关推荐
彭刷子5 小时前
【Bug】Nexus无法正常启动的五种解决方法
bug·nexus
黑客飓风9 小时前
从基础功能到自主决策, Agent 开发进阶路怎么走?
面试·log4j·bug
mahuifa12 小时前
C++(Qt)软件调试---bug排查记录(36)
c++·bug·软件调试
Kyln.Wu12 小时前
【python实用小脚本-205】[HR揭秘]手工党逐行查Bug的终结者|Python版代码质量“CT机”加速器(建议收藏)
开发语言·python·bug
2501_9301040420 小时前
Bug 排查日记:打造高效问题定位与解决的技术秘籍
bug
weixin_3776348420 小时前
【YOLO】数据增强bug
yolo·bug
伍哥的传说20 小时前
还在为第三方包 bug 头疼?patch-package 让你轻松打补丁!
bug·开发效率·前端工具·第三方包bug·前端开发痛点·npm包修复·依赖包定制
黑客飓风20 小时前
Bug排查日记:从崩溃到修复的实战记录
log4j·bug
As33100101 天前
Bug 排查日记:从问题浮现到解决的技术之旅
bug
黑客思维者2 天前
《我是如何用C语言写工控系统的漏洞和Bug》连载(1)内容大纲
c语言·bug·工控漏洞