windows+python3.7+django2.1.1+redis+django_celery_beat1.5.0+django_celery_result1.1.1 定时任务

  1. 安装celery、 django_celery_beat 和 django_celery_result ,redis安装配置略

  2. 创建Django工程和App
    工程的初始化__init__.py文件:
    windows+python3.7+django2.1.1+redis+django_celery_beat1.5.0+django_celery_result1.1.1 定时任务_第1张图片

  3. 相比普通django工程,工程里面新增py文件celery ,App里面新增py文件tasks,此处文件名必须是tasks
    windows+python3.7+django2.1.1+redis+django_celery_beat1.5.0+django_celery_result1.1.1 定时任务_第2张图片

  4. 修改工程setting.py文件:
    4.1注册app:
    windows+python3.7+django2.1.1+redis+django_celery_beat1.5.0+django_celery_result1.1.1 定时任务_第3张图片
    4.2 新增配置:
    windows+python3.7+django2.1.1+redis+django_celery_beat1.5.0+django_celery_result1.1.1 定时任务_第4张图片

  5. 编辑celery.py文件

from __future__ import absolute_import,unicode_literals
import os
from celery import Celery,platforms
from django.conf import settings

os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'celeryProject.settings')

broker = 'redis://localhost:6379/0'
app = Celery('celeryProject',broker=broker)

# app.conf.timezone = 'Asia/Shanghai'

app.config_from_object('django.conf:settings',namespace='CELERY')

app.autodiscover_tasks(lambda: settings.INSTALLED_APPS)

platforms.C_FORCE_ROOT = True

@app.task(bind=True)
def debug_task(self):
    print('Request:{0!r}'.format(self.request))
  1. 编辑tasks.py文件
from __future__ import absolute_import,unicode_literals
from celery import shared_task

@shared_task
def add(x,y):
    print("1+1")
    return x+y

@shared_task
def sub(x,y):
    print("1-1")
    return x-y
  1. 与普通工程一样,创建超级用户,生成数据库表结构等等

  2. 进入后台,可以看到CELERY RESULTS 和 CELERY TASKS
    windows+python3.7+django2.1.1+redis+django_celery_beat1.5.0+django_celery_result1.1.1 定时任务_第5张图片

  3. 点击Period task 配置任务,可以看到成功新建定时任务add,每个60s执行一次
    windows+python3.7+django2.1.1+redis+django_celery_beat1.5.0+django_celery_result1.1.1 定时任务_第6张图片

  4. 启动celery worker
    方法一:Terminal中输入指令:celery -A worker --pool=solo -l info
    方法二:安装eventlet:pip install eventlet;然后Terminal中输入指令:celery -A worker -l info -P eventlet
    windows+python3.7+django2.1.1+redis+django_celery_beat1.5.0+django_celery_result1.1.1 定时任务_第7张图片
    tip: myproject 就是你的工程名字

  5. 启动celery beat
    Terminal中输入指令:celery -A beat -l info
    windows+python3.7+django2.1.1+redis+django_celery_beat1.5.0+django_celery_result1.1.1 定时任务_第8张图片

  6. 后台CELERY TASKS查看任务状态,看到success就稳啦!
    windows+python3.7+django2.1.1+redis+django_celery_beat1.5.0+django_celery_result1.1.1 定时任务_第9张图片

你可能感兴趣的:(python,django,celery)