Gunicorn部署flask项目apscheduler重复加载定时任务的解决方案

flask加apscheduler重复加载问题已经不是新问题了。
众所周知,单机运行只需要在app.run()中增加use_reloader=False即可解决
但是到服务器采用gunicorn部署时老问题又出现了。
查阅各种资料均无法解决。
gunicorn worker 使用 sync
个数为4个
解决过程如下:
1.gunicorn启动配置中增加–preload,无效。
2.编写单例模式实例化apscheduler,但是worker每个进程均会实例化,导致定时任务重复加载,无效。
3.根据网上提供的经验,使用文件锁,无效
4.既然文件锁不行,不如试试线程锁,居然生效了,但是好景不长,增加新的定时任务后,新的定时任务会重复加载,但是之前任务不会重复加载,很神奇,最终依然无法解决。
5.最后使用杀手锏,最low的方法,实例化apscheduler时,增加父ID判断,if os.getppid() == 1,实例化apscheduler,否则不实例化,问题解决

总结:解决gunicorn部署flask项目,apscheduler重复加载的方法为,加入父ID判断。
实践再一次证明:所有高级算法背后,都有一个if else撑腰。
以上内容为手机编辑,稍后电脑编辑时上代码!

你可能感兴趣的:(笔记)