flask celery定时任务

本文介绍了如何使用Celery配置和启动定时任务。首先,在配置文件中设置broker_url和result_backend,并添加定时任务入口。然后,在指定模块创建任务函数。最后,通过shell脚本启动Celery worker和beat服务来执行定时任务。
摘要由CSDN通过智能技术生成

普通的worker是为了执行异步任务,如果想开启定时任务,则需要启动beat服务

具体配置流程如下:

1、配置config

CELERY = {
    "broker_url": "***",
    "result_backend": "***",
    # 定时任务
    'imports': (
        'apps.tasks.scheduled_task',
    ),
    "beat_schedule": {
        'per_5_sec': {
            'task': 'test_func',
            "schedule": datetime.timedelta(seconds=5),
            "args": (),
        },
    },
}

2、在对应路径下创建func

参考以上配置,则需要在apps.tasks.scheduled_task.py下,创建test_func

@celery.task(name='test_func')
def test_func():
    print('{}-test_func -- print'.format(datetime.datetime.now()))

3、创建启动celery的shell

#!/bin/bash

log_path="/日志路径/"

worker_file="celery.log"
schedule_file="celerybeat-schedule"
worker_file_path=$log_path$worker_file
schedule_file_path=$log_path$schedule_file

celery -A apps.celery_app:app worker -l info -c 3 -f $worker_file_path &
celery -A apps.celery_app:app beat -l info -s $schedule_file_path

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
Python Celery是一个分布式任务队列框架,它可以让你在分布式系统中异步执行任务。它支持定时任务的调度,可以让你在指定的时间间隔或者特定的时间点执行任务。 要使用Celery进行定时任务调度,你需要先安装Celery库。可以使用pip命令进行安装: ``` pip install celery ``` 安装完成后,你需要创建一个Celery实例,并配置它的任务队列和调度器。下面是一个简单的示例: ```python from celery import Celery from datetime import timedelta # 创建Celery实例 app = Celery('tasks', broker='redis://localhost:6379/0') # 配置定时任务调度器 app.conf.beat_schedule = { 'task-name': { 'task': 'tasks.task_name', # 任务函数的路径 'schedule': timedelta(seconds=10), # 任务执行的时间间隔 }, } # 定义任务函数 @app.task def task_name(): # 任务的具体逻辑 pass ``` 在上面的示例中,我们创建了一个名为`tasks`的Celery实例,并配置了Redis作为任务队列的中间件。然后,我们使用`app.conf.beat_schedule`配置了一个定时任务调度器,其中`task-name`是任务的名称,`task`是任务函数的路径,`schedule`是任务执行的时间间隔,这里设置为每10秒执行一次。最后,我们定义了一个名为`task_name`的任务函数,你可以在这个函数中编写具体的任务逻辑。 为了启动Celery定时任务调度器,你需要在终端中执行以下命令: ``` celery -A tasks beat ``` 这样,Celery就会按照你配置的时间间隔或者时间点执行定时任务。 希望以上内容能够帮助到你,如果有任何疑问,请随时提问。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值