django使用celery处理异步请求,定时周期任务
在用django写自己的平台时,有一些业务场景,一些请求处理时间太久,需要用到异步请求,还有一些定时任务和周期性的任务,刷新缓存,看了一些相关的库,最终觉得celery比较符合,故查阅文档,尝试celery的使用
celery: 用于处理异步请求
eventlet windows支持插件(celery 4以后版本不再支持windows环境,需要安装此插件)
django-celery-beat 用于定时和周期计划
django-celery-results 用于存储celery的运行结果
folower 用于监控celery的运行状态
安装包
pip3 install celery==5.0.5
pip3 install eventlet
pip3 install redis==3.5.3
pip3 install django-celery-results==2.0.1
pip3 install django-celery-beat==2.2.0
pip3 install folower
官网文档地址:https://docs.celeryq.dev/en/stable/
在项目setting.py同级目录下创建celery.py的文件,添加如下内容
cat celery.py
import os
from celery import Celery
# 设置环境变量
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'yunwei.settings')
# 实例化
app = Celery('yunwei')
# namespace='CELERY'作用是允许你在Django配置文件中对Celery进行配置
# 但所有Celery配置项必须以CELERY开头,防止冲突
app.config_from_object('django.conf:settings', namespace='CELERY')
# 自动从Django的已注册app中发现任务
app.autodiscover_tasks()
修改__init__.py文件,添加如下内容
from .celery import app as celery_app
__all__ = ('celery_app',)
修改setting.py文件,增加关于celery的配置内容
#celery相关配置
#设置消息broker
CELERY_BROKER_URL = "redis://10.6.3.10:6379/0"
CELERY_TIMEZONE