Wan_Yuan
挽远
2020-09-22 17:06
采纳率: 50%
浏览 263
已采纳

【定时任务】多线程条件下,定时任务怎么样避免并发,意思是同一个任务当第一个执行完了,第二才执行

  • 只有一个任务单独执行,其他任务依然共用一个线程
  • 单独执行的这个任务,需要操作数据库,所以只能一个时间只能有一个线程在执行
  • 这个定时任务,每分钟执行一次,大多数时候没有数据操作
  • 有数据的时候,一般执行三到五分钟

所以问题来了,每分钟执行一次,有数据的时候,此任务没有执行完成,单线程的时候,会被其他定时任务阻塞,针对这个定时任务,开启异步处理,那此任务就会在没有执行完成的时候,下个一分钟间隔到来前又执行一次

下面是小弟进行问题研究整理的相关笔记

问题相关笔记整理

求大佬给个白嫖答案

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

5条回答 默认 最新

  • wzy_168
    Happywzy~ 2020-09-22 17:59
    已采纳

    搞个静态变量当作开关,运行前需要判断开关状态,状态不对就等待,运行完恢复状态。
    其实就是分布式锁。

    点赞 评论
  • Himly_Zhang
    Himly_Zhang 2020-09-22 17:12

    这不是消息队列解决的核心问题么,rabbitmq,rocketmq,activemq

    点赞 评论
  • jasonwzl
    jasonwzl 2020-09-22 17:14

    定时任务默认是并发执行,一个任务时间比较长的话会出现并发两个任务一起执行,

    点赞 评论
  • qq_18630487
    真-酸辣土豆丝 2020-09-23 16:50

    首先要为定时任务配置线程池,否则会互相影响,丢任务。其次分布式系统中的定时任务一般是单独做一个服务的。其他服务提供执行接口由定时服务统一调用

    点赞 评论
  • gupao222
    咕泡-灰灰老师 2021-07-19 16:29

    分布式锁 或者 队列都可以的

    点赞 评论

相关推荐