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的扩展支持。

相关推荐
大鹏1988几秒前
Go 实战 LeetCode 151:高效翻转字符串中的单词(含空格处理技巧)
后端
Dxy12393102163 分钟前
Python使用正则提取字符串中的数字
python
花果山总钻风15 分钟前
SQLAlchemy各种排序示例
后端·python·中间件
uzong31 分钟前
管理者不要被琐事耗尽心力
后端
最贪吃的虎32 分钟前
windows上如何可视化访问并远程操作linux系统上运行的浏览器或者linux可视化桌面
java·linux·运维·windows·分布式·后端·架构
大黄说说35 分钟前
Python 实战指南:一键批量旋转 PDF 页面方向
开发语言·python·pdf
shangyingying_11 小时前
图像质量评价(IQA)
人工智能·python·神经网络
OPEN-Source1 小时前
大模型 Agent 实战:多 Agent 太贵太慢?一套系统性的性能与成本优化方案
人工智能·python·agent·rag·deepseek
南囝coding1 小时前
Claude Code 作者再次分享 Anthropic 内部团队使用技巧
前端·后端