python apscheduler不一致

问题描述 投票:3回答:2

我正在使用web.py框架内的python apscheduler运行调度程序。函数runserver应该每天在上午9点运行,但是不一致。它运行大多数天,但有时会跳过一天。

代码:

import web
from apscheduler.schedulers.blocking import BlockingScheduler #Blocking Scheduler

#URLs
urls = (
    '/startscheduler/','index',
    )

Nightlysched = BlockingScheduler()

@Nightlysched.scheduled_job('cron', hour=9)
def runserver():
    print 2+2 #doing some calculations here

#Main function to run the cron JOB
if __name__ == "__main__":
    Nightlysched.start() #stating the job
    app = web.application(urls, globals())
    app.run() 

配置调度程序每天在上午9点运行的正确方法是什么?

python scheduler blocking web.py apscheduler
2个回答
10
投票

APScheduler具有宽限期”,在此期间允许运行作业。如果由于某种原因,调度程序很忙和/或主机的负载过高,则APScheduler可能无法及时启动作业。

在这种情况下,如果无法在宽限期内启动作业,则该作业将被丢弃(如果初始化了Python日志记录,则会记录一条说明性消息。

取决于实际的根本原因:

  • 如果调度程序无法及时调度作业,您可以使用misfire_grace_time=None告诉APScheduler尽快调度作业,而不是将其丢弃。
  • 默认情况下,每个作业仅允许一个实例同时运行。确保上一次运行已完成。通过在添加作业时使用max_instances关键字参数,可以为调度程序允许并发运行的特定作业设置最大实例数。在这种情况下,您可能还需要使用coalesce=False。仅在作业耗时超过24小时(对于您而言)且您接受作业的两个实例可以同时运行时,才执行此操作。
  • 如果正在运行的作业太多,但是计算机负载不是很高,则意味着您有比同时运行的作业更多的作业。您可以尝试增加APScheduler executor用于运行作业的线程池的大小(这取决于您的设置,请检查:http://apscheduler.readthedocs.org/en/latest/userguide.html)。

总而言之,我首先尝试使用misfire_grace_period

@Nightlysched.scheduled_job('cron', hour=9, misfire_grace_time=None)

但是,正如@Alex所述,我不理解您的代码为何起作用,因为对Nightlysched.start()的调用应阻止并阻止您的Web应用程序运行。我猜这是粘贴的代码,并不能真正代表您正在运行的代码。对我来说,您似乎应该改用像BackgroundScheduler这样的非阻塞调度程序。


0
投票

@ jjmontes在上述情况下是否未将misfire_grace_time=None设置为此处文档中所建议的内容:https://apscheduler.readthedocs.io/en/v3.2.0/userguide.html#missed-job-executions-and-coalescing

请进一步说明。

© www.soinside.com 2019 - 2024. All rights reserved.