flask-apscheduler 定时任务被执行两次

定时任务没有被多次调用,事实上如果多次调用的话,flask-apscheduler会抛出异常。

但一开始任务还是按时执行一次,重启flask或者修改部分代码后,就发送定时任务一次执行两次了。

之所以会发生这种情况,是因为在debug模式下的Flask会生成一个子进程。

这样每当代码更改时,它就可以重新启动该进程,新的子进程会初始化并启动一个新的APScheduler,这就是为什么定时任务会执行两次的原因。

需要设置debug=False,或者设置use_reloader=Flase

python 复制代码
if __name__ == "__main__":
    app = create_app() 
    app.run(debug=False, ...)

目前在flask-apscheduler中还没有看到有效的解决方法。

个别方案是检测当前进程是否是子进程,如果是则不允许APScheduler启动。但这样增加了额外操作了复杂度。

要么就不用flask-apscheduler模块而改用其他没有与flask集成的模块,因为flask-apscheduler是flask对apscheduler的扩展支持。

相关推荐
工边页字10 小时前
面试官:请详细介绍下AI中的token,越详细越好!
前端·人工智能·后端
LSTM9710 小时前
确保文档安全:使用 C# 加密 Word 文档或设置文档权限
后端
Flittly10 小时前
【从零手写 ClaudeCode:learn-claude-code 项目实战笔记】(4)Subagents (子智能体)
python·agent
孟沐10 小时前
Java 方法与方法重载
后端
Nyarlathotep011311 小时前
LinkedList源码分析
java·后端
小林coding11 小时前
专为程序员打造的简历模版来啦!覆盖前端、后端、测开、大模型等专业简历
前端·后端
UrbanJazzerati11 小时前
当网页翻页时,页码藏在哪里?——一次对分页机制的解密之旅
后端·面试
用户44904120955611 小时前
一次生产环境下的Redis连接耗尽问题排查与解决全过程
后端
Tapir11 小时前
被 Karpathy 下场推荐的 NanoClaw 是什么来头
前端·后端·github
ssshooter12 小时前
Tauri 项目实践:客户端与 Web 端的授权登录实现方案
前端·后端·rust