flask-apscheduler 使用sqlite3进行持久化存储的配置(非纯apscheduler)解决flask-apscheduler无法持久化存储job的问题

先说结论: 在flask 中配置 "SCHEDULER_JOBSTORES" 变量 例子如下:

SCHEDULER_JOBSTORES = {
        'default': SQLAlchemyJobStore(url='sqlite:///jobstores.db')
    }

在apscheduler 创建之前 flask 的app 实例载入配置即可

DEBUG   过程简述~

1. 纯apscheduler 在使用持久化时候可以使用多种方法 举一个例子:

jobstores = {
    'default': SQLAlchemyJobStore(url='sqlite:///jobstores.db')
}

executes = {
    'default': ThreadPoolExecutor(10)
}
scheduler = BackgroundScheduler(jobstores=jobstores, executes=executes)

2. 在创建flask的apscheduler实例时候可以指定一个scheduler

tempScheduler = BackgroundScheduler()
scheduler = APScheduler(scheduler=tempScheduler)

3. 由此推断可以将 (1)1 里面的sheduler 赋值到 (2)中就可以正常运行时错误的

4. 遇到的问题 scheduler 可以正常使用,但是已经添加的JOB第二次启动时候无法正确载入,对应的sqlite路径没有创建对应的.db文件,简单的说你添加的job没有存进你想要的sqlite里

5.ctrl+左键(pycharm中)查看Apscheduler类的源码第 300行左右:

#ctrl+左键点击 APScheduler
scheduler = APScheduler(scheduler=tempScheduler)
    # 源码第 300行左右有写: 这个jobstore的配置是由 flask 的配置文件导入的
    def _load_config(self):
        """
        Load the configuration from the Flask configuration.
        """
        options = dict()

        job_stores = self.app.config.get('SCHEDULER_JOBSTORES')
        if job_stores:
            options['jobstores'] = job_stores

        executors = self.app.config.get('SCHEDULER_EXECUTORS')
        if executors:
            options['executors'] = executors

        job_defaults = self.app.config.get('SCHEDULER_JOB_DEFAULTS')
        if job_defaults:
            options['job_defaults'] = job_defaults

        timezone = self.app.config.get('SCHEDULER_TIMEZONE')
        if timezone:
            options['timezone'] = timezone

        self._scheduler.configure(**options)
    ......

这里可以看到,相关的配置是借由flask的app实例传入的,并不是用scheduler中提取的。

6. 配置的注意事项: 使用 app.config.from_object 好用

本人使用 app.config["SCHEDULER_JOBSTORES"] = {....} 这个模式并不起作用,可能是因为

本身代码就有载入配置的语句app.config.from_object(config),可能是这个配置有排他性(有这个其他方式不起作用?)这里大家可能需要注意下。

PS: 在步骤3 中提到的 BackgroundScheduler() 可以正常使用,却不能使用jobstore=xx 的模式配置jobstore的原因是flask-apscheduler 中的APScheduler 并不完全是普通的Scheduler(没有从BaseScheduler中继承),因此其使用及初始化不完全相同,有兴趣的可以看下源码。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Flask-APscheduler 是一个在 Flask 框架中使用 APscheduler 的扩展包。APscheduler 是一个 Python 中的定时任务框架。使用 Flask-APscheduler 可以在 Flask 项目中方便地使用定时任务。常见场景包括: - 定时执行爬虫程序 - 定时发送邮件 - 定时备份数据库 - 定时清理无用文件 等等。 ### 回答2: flask-apscheduler是一个用于在Flask应用中调度定时任务的扩展。它基于APScheduler库,并提供了一种简单而灵活的方式来安排和管理这些任务。flask-apscheduler使用场景如下: 1. 定时任务调度:使用flask-apscheduler可以轻松地在Flask应用中安排和管理定时任务。无论是需要每天定时执行数据备份、生成报表,还是需要每小时定时清理临时文件等任务,都可以通过flask-apscheduler来实现。 2. 异步任务处理:通过flask-apscheduler,可以将一些耗时的任务转为后台异步执行,提高系统的响应性能。比如,可以使用flask-apscheduler来处理邮件发送、文件处理、数据分析等耗时任务,让主线程及时返回给用户响应,并将耗时任务交给flask-apscheduler来异步处理。 3. 定时消息推送:flask-apscheduler可以用于定时推送消息给用户。比如,在特定的时间点上,通过flask-apscheduler可以安排发送提醒消息给用户,如节假日祝福、活动通知等,提升用户的参与度和满意度。 4. 定时数据更新:使用flask-apscheduler可以定时更新数据库中的数据,保持数据的最新性。通过设定合适的定时任务,可以定期从外部数据源获取最新数据,或者利用一些算法对数据库中的数据进行更新和优化,保持系统的稳定性和性能。 总之,flask-apschedulerFlask应用中可以广泛应用于定时任务调度、异步任务处理、定时消息推送和定时数据更新等场景。它提供了简单且灵活的方式来管理这些任务,提高系统的性能和用户体验。 ### 回答3: flask-apscheduler是一个基于Flask框架的定时任务调度插件,用于在Flask应用程序中自动执行预定义的任务。它可以在特定的时间间隔内启动、暂停或终止任务。 flask-apscheduler使用场景可以包括以下几个方面: 1. 定时任务执行:flask-apscheduler可以用于在指定的时间间隔内执行一些任务,比如定期清理数据库、定时发送邮件、定时生成报表等。通过预先定义的调度器和任务函数,可以很方便地配置和管理这些定时任务。 2. 后台处理:在一些需要长时间处理的业务场景中,可以使用flask-apscheduler将这些任务放入后台进行处理,而不会阻塞主线程。比如在用户提交一个表单后需要进行数据处理或发送通知,在后台执行任务可以提升用户的体验。 3. 数据同步:flask-apscheduler还可以用于调度不同数据库之间的数据同步任务。例如,将从一个数据库中提取的数据同步到另一个数据库中,可以使用定时任务来定期检查数据更新并执行同步操作。 4. 缓存刷新:如果应用程序中有一些需要定期刷新的缓存数据,可以使用flask-apscheduler来定时更新这些数据,确保数据的及时性和准确性。 总而言之,flask-apscheduler适用于需要定时执行任务、后台处理、数据同步和缓存刷新等场景。它提供了简单易用的API和配置方式,使得在Flask应用程序中实现定时任务调度变得非常方便。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值