python中BackgroundScheduler和BlockingScheduler的区别

这篇文章主要介绍了python中BackgroundScheduler和BlockingScheduler的区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

pythonBackgroundSchedulerBlockingScheduler的区别,久久派带你了解更多相关信息。

目录
  • 1、基本的定时调度
  • 2、BlockingScheduler与BackgroundScheduler区别

APScheduler最基本的用法: “定时几秒后启动job”
两种调度器: BackgroundScheduler和BlockingScheduler的区别,
job执行时间大于定时调度时间特殊情况的问题及解决方法
每个job都会以thread的方式被调度。

1、基本的定时调度

APScheduler是python的一个定时任务调度框架,能实现类似linux下crontab类型的任务,使用起来比较方便。它提供基于固定时间间隔、日期以及crontab配置类似的任务调度,并可以持久化任务,或将任务以daemon方式运行。

下面是一个最基本的使用示例:

from apscheduler.schedulers.blocking import BlockingSchedulerdef job():    print(\'job 3s\')if __name__==\'__main__\':    sched = BlockingScheduler(timezone=\'MST\')    sched.add_job(job, \'interval\', id=\'3_second_job\', seconds=3)    sched.start()

它能实现每隔3s就调度job()运行一次,所以程序每隔3s就输出\’job 3s\’。通过修改add_job()的参数seconds,就可以改变任务调度的间隔时间。

2、BlockingScheduler与BackgroundScheduler区别

APScheduler中有很多种不同类型的调度器,BlockingScheduler与BackgroundScheduler是其中最常用的两种调度器。那他们之间有什么区别呢? 简单来说,区别主要在于BlockingScheduler会阻塞主线程的运行,而BackgroundScheduler不会阻塞。所以,我们在不同的情况下,选择不同的调度器:

BlockingScheduler: 调用start函数后会阻塞当前线程。当调度器是你应用中唯一要运行的东西时(如上例)使用。
BackgroundScheduler: 调用start后主线程不会阻塞。当你不运行任何其他框架时使用,并希望调度器在你应用的后台执行。
下面用两个例子来更直观的说明两者的区别。

BlockingScheduler例子

from apscheduler.schedulers.blocking import BlockingSchedulerimport timedef job():    print(\'job 3s\')if __name__==\'__main__\':    sched = BlockingScheduler(timezone=\'MST\')    sched.add_job(job, \'interval\', id=\'3_second_job\', seconds=3)    sched.start()    while(True): # 不会被执行到        print(\'main 1s\')        time.sleep(1)

运行这个程序,我们得到如下的输出:

job 3s
job 3s
job 3s
job 3s

可见,BlockingScheduler调用start函数后会阻塞当前线程,导致主程序中while循环不会被执行到。

BackgroundScheduler例子

from apscheduler.schedulers.background import BackgroundSchedulerimport timedef job():    print(\'job 3s\')if __name__==\'__main__\':    sched = BackgroundScheduler(timezone=\'MST\')    sched.add_job(job, \'interval\', id=\'3_second_job\', seconds=3)    sched.start()    while(True):        print(\'main 1s\')        time.sleep(1)

可见,BackgroundScheduler调用start函数后并不会阻塞当前线程,所以可以继续执行主程序中while循环的逻辑。

main 1s
main 1s
main 1s
job 3s
main 1s
main 1s
main 1s
job 3s

通过这个输出,我们也可以发现,调用start函数后,job()并不会立即开始执行。而是等待3s后,才会被调度执行。
如何让job在start()后就开始运行
如何才能让调度器调用start函数后,job()就立即开始执行呢?

其实APScheduler并没有提供很好的方法来解决这个问题,但有一种最简单的方式,就是在调度器start之前,就运行一次job(),如下

from apscheduler.schedulers.background import BackgroundSchedulerimport timedef job():    print(\'job 3s\')if __name__==\'__main__\':    job() # 执行一次就好了哟    sched = BackgroundScheduler(timezone=\'MST\')    sched.add_job(job, \'interval\', id=\'3_second_job\', seconds=3)    sched.start()    while(True):        print(\'main 1s\')        time.sleep(1)

这样就能得到如下的输出

job 3s
main 1s
main 1s
main 1s
job 3s
main 1s
main 1s
main 1s

这样虽然没有绝对做到“让job在start()后就开始运行”,但也能做到“不等待调度,而是刚开始就运行job”。

如果job执行时间过长会怎么样
如果执行job()的时间需要5s,但调度器配置为每隔3s就调用一下job(),会发生什么情况呢?我们写了如下例子:

from apscheduler.schedulers.background import BackgroundSchedulerimport timedef job():    print(\'job 3s\')    time.sleep(5)if __name__==\'__main__\':    sched = BackgroundScheduler(timezone=\'MST\')    sched.add_job(job, \'interval\', id=\'3_second_job\', seconds=3)    sched.start()    while(True):        print(\'main 1s\')        time.sleep(1)

运行这个程序,我们得到如下的输出:

main 1s
main 1s
main 1s
job 3s
main 1s
main 1s
main 1s
Execution of job \”job (trigger: interval[0:00:03], next run at: 2018-05-07 02:44:29 MST)\” skipped: maximum number of running instances reached (1)
main 1s
main 1s
main 1s
job 3s
main 1s

可见,3s时间到达后,并不会“重新启动一个job线程”,而是会跳过该次调度,等到下一个周期(再等待3s),又重新调度job()。

为了能让多个job()同时运行,我们也可以配置调度器的参数max_instances,如下例,我们允许2个job()同时运行:

from apscheduler.schedulers.background import BackgroundSchedulerimport timedef job():    print(\'job 3s\')    time.sleep(5)if __name__==\'__main__\':    job_defaults = { \'max_instances\': 2 }    sched = BackgroundScheduler(timezone=\'MST\', job_defaults=job_defaults)    sched.add_job(job, \'interval\', id=\'3_second_job\', seconds=3)    sched.start()    while(True):        print(\'main 1s\')        time.sleep(1)

运行程序,我们得到如下的输出:

main 1s
main 1s
main 1s
job 3s
main 1s
main 1s
main 1s
job 3s
main 1s
main 1s
main 1s
job 3s

每个job是怎么被调度的

通过上面的例子,我们发现,调度器是定时调度job()函数,来实现调度的。

那job()函数会被以进程的方式调度运行,还是以线程来运行呢?

为了弄清这个问题,我们写了如下程序:

from apscheduler.schedulers.background import BackgroundSchedulerimport time,os,threadingdef job():    print(\'job thread_id-{0}, process_id-{1}\'.format(threading.get_ident(), os.getpid()))    time.sleep(50)if __name__==\'__main__\':    job_defaults = { \'max_instances\': 20 }    sched = BackgroundScheduler(timezone=\'MST\', job_defaults=job_defaults)    sched.add_job(job, \'interval\', id=\'3_second_job\', seconds=3)    sched.start()    while(True):        print(\'main 1s\')        time.sleep(1)

运行程序,我们得到如下的输出:

main 1s
main 1s
main 1s
job thread_id-10644, process_id-8872
main 1s
main 1s
main 1s
job thread_id-3024, process_id-8872
main 1s
main 1s
main 1s
job thread_id-6728, process_id-8872
main 1s
main 1s
main 1s
job thread_id-11716, process_id-8872

可见,每个job()的进程ID都相同,但线程ID不同。所以,job()最终是以线程的方式被调度执行。

到此这篇关于python中BackgroundScheduler和BlockingScheduler的区别 的文章就介绍到这了,更多相关python BackgroundScheduler BlockingScheduler内容请搜索趣讯吧以前的文章或继续浏览下面的相关文章希望大家以后多多支持趣讯吧!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,请发送邮件至 55@qq.com 举报,一经查实,本站将立刻删除。转转请注明出处:https://www.szhjjp.com/n/7237.html

(0)
nan
上一篇 2021-07-29
下一篇 2021-07-29

相关推荐

  • 优美散文片段500字摘抄(精美散文片段摘抄500字)

    忽然一觉醒来,窗外还是沉黑的,只有一盏高悬的路灯,在远处爆发着无数刺眼的光线!我的飞扬的心灵,又落进了痛楚的躯壳。我忽然想起老子的几句话:吾有大患,及吾有身;及吾无身,吾有何患。这时我感觉到了躯壳给人类的痛苦。而且人类也有精神上的痛苦:大之如

    2022-01-14
    0
  • 贷款购房房产证的规定(贷款购房房产证什么时候下来)

    由于房屋价格的原因,导致很多人在买房的时候都是属于首次买房,对于首次买房的购房者来说,在买房的时候只知道自己买房之后就可以办理房产证,但是对于办理的时间却不太了解,那么接下来大家就来一起了解一下房产证一般什么时候能够拿到以及买房拿不到房产证

    2021-12-15
    0
  • 处暑有什么特点?处暑的气候特点是什么

    处暑这个节气其实也就是一种谐音,也就是大家常说的出暑,这个意思就是意味着将要结束炎热的夏天,即将进入凉爽的秋天,那么这个处暑有什么特点,处暑的气候特点是什么,接下来大家就随趣讯吧小编一起了解看看~

    2021-08-02
    0
  • iPhone13ProMax参数配置?参数详情

    iPhone13ProMax是苹果秋季发布会将要推出的新品手机,最近关于iPhone13ProMax的消息越来越多,秋季发布会也一款进入倒计时,下面是小编整理的iPhone13ProMax参数配置详情,大家可以参考参考哦~

    2021-08-23 热点头条
    0
  • 世界笔记本电脑排名有哪些牌子(全球国际笔记本电脑排名)

    近日,陆续有调研机构公布了相关的市场调查报告。StrategyAnalytics也于最近发布了2021年第三季度全球笔记本电脑出货量和市场份额初步报告。报告中提到,尽管出现了零部件短缺等情况,但笔记本电脑市场仍实现了又一个不错的季度增长,同比增长8

    2022-01-14 热点头条
    0
  • 五一假期淄博烧烤店轮班休息 !网友:第一次见做生意的调休的!

    4月28日,山东淄博。五一期间淄博浅海市场的烧烤店轮班休息,有网友表示,第一次见做生意的调休。浅海王老三烧烤店回应,5月1日的确不营业,全国人民都放假,他们也放假一天。只要来淄博还是能吃上烧烤,可以预约其他地方的。休息一天对店里没有影响,员工休息好了,第二天状态更好更快,接待的顾客更多。针对此事,网

    热点头条 2023-04-29
    0

发表回复

登录后才能评论