nonebot2/website/versioned_docs/version-2.0.0rc2/advanced/scheduler.md
github-actions[bot] d83866f03b 🔖 Release 2.0.0rc2
2022-11-24 03:55:37 +00:00

4.4 KiB
Raw Blame History

sidebar_position description options
1 在 NoneBot2 中使用定时任务
menu
weight category
20 advanced

定时任务

APScheduler —— Advanced Python Scheduler

Advanced Python Scheduler (APScheduler) is a Python library that lets you schedule your Python code to be executed later, either just once or periodically. You can add new jobs or remove old ones on the fly as you please. If you store your jobs in a database, they will also survive scheduler restarts and maintain their state. When the scheduler is restarted, it will then run all the jobs it should have run while it was offline.

从 NoneBot v1 迁移

APScheduler 作为 NoneBot v1 的可选依赖,为众多 bot 提供了方便的定时任务功能。NoneBot2 已将 APScheduler 独立为 nonebot_plugin_apscheduler 插件,你可以在商店中找到它。

相比于 NoneBot v1NoneBot v2 只需要安装插件并修改 scheduler 的导入方式即可完成迁移。

安装插件

通过 nb-cli

如正在使用 nb-cli 构建项目,你可以从插件市场复制安装命令或手动输入以下命令以添加 nonebot_plugin_apscheduler。

nb plugin install nonebot_plugin_apscheduler

:::tip 提示 nb-cli 默认通过 PyPI 安装,你可以添加命令参数 -i [mirror]--index [mirror] 以使用镜像源安装。 :::

通过 Poetry

执行以下命令以添加 nonebot_plugin_apscheduler

poetry add nonebot-plugin-apscheduler

:::tip 提示 由于稍后我们将使用 nonebot.require() 方法进行声明依赖,所以无需额外的 nonebot.load_plugin() :::

快速上手

  1. 在需要设置定时任务的插件中,通过 nonebot.require 声明插件依赖
  2. 从 nonebot_plugin_apscheduler 导入 scheduler 对象
  3. 在该对象的基础上,根据 APScheduler 的使用方法进一步配置定时任务

将上述步骤归纳为最小实现的代码如下:

from nonebot import require

require("nonebot_plugin_apscheduler")

from nonebot_plugin_apscheduler import scheduler

@scheduler.scheduled_job("cron", hour="*/2", id="xxx", args=[1], kwargs={"arg2": 2})
async def run_every_2_hour(arg1, arg2):
    pass

scheduler.add_job(run_every_day_from_program_start, "interval", days=1, id="xxx")

分步进行

导入 scheduler 对象

为了使插件能够实现定时任务,需要先将 scheduler 对象导入插件。

NoneBot2 提供了 nonebot.require 方法来实现声明插件依赖,确保 nonebot_plugin_apscheduler 插件可以在使用之前被导入。声明完成即可直接通过 import 导入 scheduler 对象。

NoneBot2 使用的 scheduler 对象为 AsyncIOScheduler

from nonebot import require

require("nonebot_plugin_apscheduler")

from nonebot_plugin_apscheduler import scheduler

编写定时任务

由于本部分为标准的通过 APScheduler 配置定时任务,有关指南请参阅 APScheduler 官方文档

配置插件选项

根据项目的 .env 文件设置,向 .env.*bot.py 文件添加 nonebot_plugin_apscheduler 的可选配置项

:::warning 注意 .env.* 文件的编写应遵循 NoneBot2 对 .env.* 文件的编写要求 :::

apscheduler_autostart

类型:bool

默认值:True

是否自动启动 APScheduler

对于大多数情况,我们需要在 NoneBot2 项目被启动时启动定时任务,则此处设为 true

.env 中添加
APSCHEDULER_AUTOSTART=true
bot.py 中添加
nonebot.init(apscheduler_autostart=True)

apscheduler_config

类型:dict

默认值:{"apscheduler.timezone": "Asia/Shanghai"}

APScheduler 相关配置。修改/增加其中配置项需要确保 prefix: apscheduler

对于 APScheduler 的相关配置,请参阅 scheduler-configBaseScheduler

官方文档在绝大多数时候能提供最准确和最具时效性的指南

.env 中添加
APSCHEDULER_CONFIG={"apscheduler.timezone": "Asia/Shanghai"}
bot.py 中添加
nonebot.init(apscheduler_config={
    "apscheduler.timezone": "Asia/Shanghai"
})