我在 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.a.m运行的正确方法是什么?
答案 0 :(得分:4)
APScheduler有宽限期,在此期间允许作业运行。如果由于某种原因调度程序繁忙和/或主机负载过高,APScheduler可能无法及时启动作业。
在这种情况下,如果在宽限期内无法启动作业,则该作业将被丢弃(如果已初始化Python日志记录,将记录解释性消息)。
取决于实际的根本原因:
misfire_grace_time=None
告诉APScheduler尽快安排作业,而不是丢弃它。max_instances
关键字参数,可以设置调度程序将允许并发运行的特定作业的最大实例数。在这种情况下,您可能还需要使用coalesce=False
。只有在工作时间超过24小时(在您的情况下)并且您接受两个工作实例可以同时运行时才执行此操作。总之,我首先尝试misfire_grace_period
:
@Nightlysched.scheduled_job('cron', hour=9, misfire_grace_time=None)
但请注意,正如@Alex所提到的,我不明白为什么您的代码有效,因为对Nightlysched.start()
的调用应该阻止并阻止您的Web应用程序运行。我想这是粘贴的代码,并不能真正代表您正在运行的内容。对我来说,看起来你应该使用像BackgroundScheduler这样的非阻塞调度程序。
答案 1 :(得分:0)
为了顺利执行,您还可以尝试 simple-scheduler。为什么?
示例:
from simple_scheduler.recurring import recurring_scheduler
from multiprocessing import Process
def f1():
print("Hi")
def f2():
print("...")
def run_processes():
p1 = Process(target = f1)
p1.start()
p2 = Process(target = f2)
p2.start()
p1.join()
p2.join()
print("finished")
recurring_scheduler.add_job(target=run_processes,
period_in_seconds=5,
job_name="run_processes")
recurring_scheduler.job_summary()
recurring_scheduler.run()
recurring_scheduler.job_summary()