Python BackgroundScheduler中Interval、Cron及偏移量的使用方法

2024年 3月 21日 34.9k 0

Python中interval和cron的使用方法

  • apscheduler 库 是 Python 中一个功能强大的定时任务库。
  • interval 和 cron 是 apscheduler 库中常用的两种触发器类型。
  • interval 触发器 用于指定任务执行的间隔时间。
  • cron 触发器 用于指定任务执行的时间表达式。

以下是 interval 和 cron 的使用方法:

1. interval 触发器

示例:

from apscheduler.schedulers.background import BackgroundScheduler

def job1():
    logging.info(f'{time.strftime("%Y-%m-%d %H:%M:%S", time.localtime(time.time()))} 执行')

# 创建调度器
scheduler = BackgroundScheduler()

# 添加定时任务
scheduler.add_job(job1, 'interval', seconds=3600)

# 启动调度器
scheduler.start()

以上代码将每小时执行一次 job1() 函数。

2. interval 偏移量

interval 触发器 支持偏移量,用于指定任务执行时间的随机偏移量。

语法:

scheduler.add_job(func, 'interval', seconds=3600, jitter=3600)

参数:

  • jitter: 偏移量

当使用 BackgroundScheduler 的 add_job 方法时,可以通过 jitter 参数来添加偏移量,以增加任务执行时间的随机性。jitter 是一个可选参数,用于指定任务执行时间的随机偏移范围。

具体来说,jitter 参数允许你在指定的时间间隔内随机选择一个偏移量,将它添加到任务的执行时间上。这样可以避免在同一时间执行大量任务,减轻系统负载和资源竞争。

示例:

from apscheduler.schedulers.background import BackgroundScheduler

def job1():
    logging.info(f'{time.strftime("%Y-%m-%d %H:%M:%S", time.localtime(time.time()))} 执行')

# 创建调度器
scheduler = BackgroundScheduler()

# 添加定时任务
scheduler.add_job(job1, 'interval', seconds=3600, jitter=3600)

# 启动调度器
scheduler.start()

以上代码使用 add_job 方法添加了一个任务,并使用 interval 触发器指定了任务的执行方式。seconds=3600 表示任务将每隔 3600 秒(1 小时)执行一次。jitter=3600 表示在每次任务执行时间的基础上,随机选择一个介于 -3600 和 3600 秒之间的偏移量。这样,任务的实际执行时间将在每小时的范围内有轻微的随机变化。

通过使用 jitter 偏移量,可以避免多个任务在完全相同的时间点执行,从而更好地分散任务负载并提高系统的可靠性和性能。

需要注意的是,jitter 偏移量的单位与触发器中指定的时间间隔单位相同。在上述示例中,seconds=3600 表示时间间隔为秒,因此 jitter=3600 的单位也是秒。如果使用其他时间单位(如分钟或小时),则偏移量应相应地进行调整。

总结:jitter 偏移量允许你给任务的执行时间添加一定的随机性,以避免任务在完全相同的时间点执行。通过在 add_job 方法中设置 jitter 参数,你可以控制偏移量的范围和单位,以满足任务调度的需求。

3. cron 触发器

示例:

from apscheduler.schedulers.background import BackgroundScheduler

def job1():
    logging.info(f'{time.strftime("%Y-%m-%d %H:%M:%S", time.localtime(time.time()))} 执行')

# 创建调度器
scheduler = BackgroundScheduler()

# 添加定时任务
scheduler.add_job(job1, 'cron', hour='*')

# 启动调度器
scheduler.start()

以上代码将在每小时的 00 分执行一次 job1() 函数。

4.cron 时间表达式

cron 触发器 支持时间表达式,用于指定任务执行的时间。

时间表达式的格式:

分钟 小时 天 月 星期

每个字段可以使用以下值:

  • *: 表示所有值
  • ,: 表示分隔符
  • -: 表示范围
  • /: 表示间隔

示例:

from apscheduler.schedulers.background import BackgroundScheduler

def job1():
    logging.info(f'{time.strftime("%Y-%m-%d %H:%M:%S", time.localtime(time.time()))} 执行')

# 创建调度器
scheduler = BackgroundScheduler()

# 添加定时任务
scheduler.add_job(job1, 'cron', hour='12', minute='30')

# 启动调度器
scheduler.start()

以上代码将在12点的 30 分执行一次 job1() 函数。

相关文章

JavaScript2024新功能:Object.groupBy、正则表达式v标志
PHP trim 函数对多字节字符的使用和限制
新函数 json_validate() 、randomizer 类扩展…20 个PHP 8.3 新特性全面解析
使用HTMX为WordPress增效:如何在不使用复杂框架的情况下增强平台功能
为React 19做准备:WordPress 6.6用户指南
如何删除WordPress中的所有评论

发布评论