python+django+djcelery 入门级踩坑

本文介绍了如何使用Python的Django框架结合Celery和Redis进行任务调度。首先通过pip安装相关库,然后配置settings.py,设置Redis为Broker。接着创建tasks.py定义任务,最后在Django后台添加定时任务,并分别启动worker和beat来执行任务。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

开始:

  1. 首先安装django-celery,使用Redis作为Broker还需要安装celery-with-redis:
    pip install django-celery
    pip install celery-with-redis
    
    sudo apt-get install redis-server
    如果没有redis-server则不能开启redis默认的6379端口, 在后续的执行定时任务时, 会报错 beat: connection error...
    
    


  2. setting.py配置
    import djcelery
    djcelery.setup_loader()    #加载djcelery
    BROKER_URL = 'redis://localhost:6379/0'    #Broker使用Redis, 使用0数据库(暂时不是很清楚原理)
    CELERYBEAT_SCHEDULER = 'djcelery.schedulers.DatabaseScheduler'    #Backend数据库
    INSTALLED_APPS = (
    ...
    'djcelery' #注册下载的django-celery
    )
    
    
  3. 在django app下建立tasks.py

    from celery import task
    @task(name=’appname.tasks.func_name’)    #appname为当前app注册的名字
    def func_name():
        print ‘测试成功’

  4. 在登录djngo后台admin/, 为periodic task 增加定时任务.


  5. 启动程序
    python manage.py runserver

  6. 启动celery woker, 用来查看输入日志.
    python manage.py celery worker -l info
    在新打开的终端执行命令.

  7. 启动心跳执行定时任务.
    python manage.py celery beat
    在另一个新打开的终端中执行命令, 如果任务顺利执行, print '测试成功' 将会显示在 woker 所在的终端里.





评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值