Python定时任务

本文介绍了Python中的多种定时任务实现方式,包括threading的Timer、sched模块、APScheduler及其组件和配置,还有Linux的Crontab和异步框架Celery。重点讲解了APScheduler的触发器、存储方式和调度器,以及django-apscheduler在Django项目中的应用。
摘要由CSDN通过智能技术生成

一、threading的Timer:

优点:非阻塞
缺点:不易管理多个任务

例如:5秒后执行

from threading import Timer

def printHello():  
    print("start" )
  
Timer(5, printHello).start()  

例如: 间隔5秒执行一次

def printHello():  
    print("start" )
    timer = threading.Timer(5,printHello)
    timer.start()
  
if __name__ == "__main__":  
    printHello()

例如:两种方式组合用,5秒钟后执行,并且之后间隔5秒执行一次

def printHello():  
    print("start")  
    timer = threading.Timer(5,printHello)
    timer.start()
  
if __name__ == "__main__":  
    timer = threading.Timer(5,printHello)
    timer.start()

二、sched模块:

sched模块实现了一个时间调度程序,该程序可以通过单线程执行来处理按照时间尺度进行调度的时间。(延时处理机制)
通过调用scheduler.enter(delay,priority,func,args)函数,可以将一个任务添加到任务队列里面,当指定的时间到了,就会执行任务(func函数)。

  • delay:任务的间隔时间。
  • priority:如果几个任务被调度到相同的时间执行,将按照priority的增序执行这几个任务。
  • func:要执行的任务函数
  • args:func的参数
import time  
import os  
import sched  
  
  
# 初始化sched模块的scheduler类  
# 第一个参数是一个可以返回时间戳的函数,第二个参数可以在定时未到达之前阻塞。  
schedule = sched.scheduler(time.time, time.sleep)  
  
# 被周期性调度触发的函数  
def execute_command(cmd, inc):  
    print('执行主程序')
    
    ''''' 
    终端上显示当前计算机的连接情况 
    '''  
    os.system(cmd)  
    schedule.enter(inc, 0, execute_command, (cmd, inc))  
  
  
def main(cmd, inc=60):  
    # enter四个参数分别为:间隔时间、优先级(用于同时间到达的两个事件同时执行时定序)、被调用触发的函数,  
    # 给该触发函数的参数(tuple形式)  
    schedule.enter(0, 0, execute_command, (cmd, inc))  
    schedule.run()  
  
  
# 每60秒查看下网络连接情况  
if __name__ == '__main__':  
    main("netstat -an", 60)

三、定时框架APScheduler:

APSScheduler是python的一个定时任务框架,它提供了基于日期date、固定时间间隔interval、以及linux上的crontab类型的定时任务。该矿机不仅可以添加、删除定时任务,还可以将任务存储到数据库中、实现任务的持久化。

APScheduler有四种组件:

  • triggers(触发器):触发器包含调度逻辑,每一个作业有它自己的触发器,用于决定接下来哪一个作业会运行,除了他们自己初始化配置外,触发器完全是无状态的。

  • job stores(作业存储):用来存储被调度的作业,默认的作业存储器是简单地把作业任务保存在内存中,其它作业存储器可以将任务作业保存到各种数据库中,支持MongoDB、Redis、SQLAlchemy存储方式。当对作业任务进行持久化存储的时候,作业的数据将被序列化,重新读取作业时在反序列化。

  • executors(执行器):执行器用来执行定时任务,只是将需要执行的任务放在新的线程或者线程池中运行。当作业任务完成时,执行器将会通知调度器。对于执行器,默认情况下选择ThreadPoolExecutor就可以了,但是如果涉及到一下特殊任务如比较消耗CPU的任务则可以选择ProcessPoolExecutor,当然根据根据实际需求可以同时使用两种执行器。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值