所以问题来了,每分钟执行一次,有数据的时候,此任务没有执行完成,单线程的时候,会被其他定时任务阻塞,针对这个定时任务,开启异步处理,那此任务就会在没有执行完成的时候,下个一分钟间隔到来前又执行一次
求大佬给个白嫖答案
搞个静态变量当作开关,运行前需要判断开关状态,状态不对就等待,运行完恢复状态。
其实就是分布式锁。
这不是消息队列解决的核心问题么,rabbitmq,rocketmq,activemq
定时任务默认是并发执行,一个任务时间比较长的话会出现并发两个任务一起执行,
首先要为定时任务配置线程池,否则会互相影响,丢任务。其次分布式系统中的定时任务一般是单独做一个服务的。其他服务提供执行接口由定时服务统一调用
分布式锁 或者 队列都可以的