1.安装包

pip install celery

pip install django-celery

pip install pymysql

2.创建一个django项目

- proj/
- proj/__init__.py
- proj/settings.py
- proj/urls.py
- manage.py

3.修改__init__.py

import pymysql
pymysql.install_as_MySQLdb()

4.修改settings.py,加celery配置

# 是否启用celery任务
IS_USE_CELERY = True
# 本地开发的 celery 的消息队列(RabbitMQ)信息
# BROKER_URL_DEV = 'amqp://guest:guest@127.0.0.1:5672/'
BROKER_URL_DEV = 'redis://127.0.0.1:6379/1'
# TOCHANGE 调用celery任务的文件路径, List of modules to import when celery starts.
CELERY_IMPORTS = (
'celerytest.task',
)
# ===============================================================================
# CELERY 配置
# ===============================================================================
if IS_USE_CELERY:
try:
import djcelery
import sys
INSTALLED_APPS += (
'djcelery', # djcelery
)
djcelery.setup_loader()
CELERY_ENABLE_UTC = False
CELERYBEAT_SCHEDULER = "djcelery.schedulers.DatabaseScheduler"
if "celery" in sys.argv:
DEBUG = False
# celery 的消息队列(redis)信息
BROKER_URL = os.environ.get('BK_BROKER_URL', BROKER_URL_DEV)
#BROKER_URL = 'amqp://guest:guest@127.0.0.1:5672/' except:
pass

5.修改settings.py,改数据库配置

# ===============================================================================
# 数据库设置, 本地开发数据库设置
# ===============================================================================
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql', # 默认用mysql
'NAME': 'celerytest', # 数据库名 (默认与APP_ID相同)
'USER': 'root', # 你的数据库user
'PASSWORD': '', # 你的数据库password
'HOST': '127.0.0.1', # 开发的时候,使用localhost
'PORT': '', # 默认3306
},
}

6.修改urls.py,添加链接

from django.conf.urls import include, url
from django.contrib import admin
import test
urlpatterns = [
url(r'^admin/', include(admin.site.urls)),
url(r'^aa/$', test.test),
url(r'^add/$', test.addtest),
url(r'^del/$', test.deltest),
url(r'^tt/$', test.startandstop),
]

7.添加task.py,celery任务

# -*- coding: utf-8 -*-
import django #测试不加如这两行启动worker要报错,而且需要加在最前
django.setup() import time
from celery import task,shared_task #直接执行
@task()
def sayhello():
print('hello ...')
time.sleep(2)
print('world ...') #定时任务
@shared_task(name="celerytest")
def everysay(**kwargs):
"""定时任务调用执行作业"""
sayadd(**kwargs) def sayadd(**kwargs):
print('add1 ...')
time.sleep(2)
print(int(kwargs['x'])+int(kwargs['y']))

8.添加test.py,调用任务

# -*- coding: utf-8 -*-
from django.shortcuts import render,HttpResponse
from task import *
from djcelery import models as djmodels
import json
def getcrontabtime(minute,hour,day_of_month,month_of_year,day_of_week):
mycrontab = {}
mycrontab['minute'] = minute
mycrontab['hour'] = hour
mycrontab['day_of_month'] = day_of_month
mycrontab['month_of_year'] = month_of_year
mycrontab['day_of_week'] = day_of_week
return mycrontab def test(request):
sayhello.delay()#如果有参数sayhello.delay(x,y,z)
return HttpResponse("hello world") def addtest(request):
'''添加定时任务'''
task, created = djmodels.PeriodicTask.objects.get_or_create(name='', task='celerytest') #task对应的是task文件里的函数方法
mycrontab = getcrontabtime(5,'*','*','*','*')
crontab = djmodels.CrontabSchedule.objects.filter(**mycrontab).first()
if crontab is None:
crontab = djmodels.CrontabSchedule.objects.create(**mycrontab)
task.crontab = crontab
task.enabled = True
param_dic = {}
param_dic['x'] = 5
param_dic['y'] = 2
# print param_dic
# if type(param_dic) == list:
# task.args = param_dic
if type(param_dic) == dict:
task.kwargs = json.dumps(param_dic)
task.save()
return HttpResponse("添加任务") def deltest(request):
'''删除定时任务'''
try:
djmodels.PeriodicTask.objects.filter(name='').delete()
except:
return HttpResponse("删除定时任务失败")
return HttpResponse("删除定时任务成功") def startandstop(request):
'''启停定时作业'''
status = request.GET.get('status','')
task, created = djmodels.PeriodicTask.objects.get_or_create(name='', task='celerytest')
if status == '':
task.enabled = False
task.save()
return HttpResponse("停用成功")
elif status == '':
task.enabled = True
task.save()
return HttpResponse("启用成功")
else:
return HttpResponse("系统错误")

9.项目架构

10.运行前准备

#配置数据库迁移,生成celery需要的数据表
python manage.py migrate
#启动Redis
sudo redis-server /etc/redis/redis.conf
#启动worker
python manage.py celery worker --loglevel=info
#启动心跳
python manage.py celery beat --max-interval=10 --loglevel=INFO
--max-interval=10 :每十秒侦测一次任务 --loglevel=INFO:日志等级是INFO

11.启动测试

#启动web
python manage.py runserver 0.0.0.0:9999
#直接执行
http://127.0.0.1:9999/aa/
#添加定时服务
http://127.0.0.1:9999/add/
#删除定时服务
http://127.0.0.1:9999/add/
#暂停执行定时服务
http://127.0.0.1:9999/tt/
http://127.0.0.1:9999/tt/?status=0
#启动执行定时服务
http://127.0.0.1:9999/tt/?status=1

Django + celery +redis使用的更多相关文章

  1. django+celery+redis环境搭建

    初次尝试搭建django+celery+redis环境,记录下来,慢慢学习~ 1.安装apache 下载httpd-2.0.63.tar.gz,解压tar zxvf httpd-2.0.63.tar. ...

  2. django celery redis 定时任务

    0.目的 在开发项目中,经常有一些操作时间比较长(生产环境中超过了nginx的timeout时间),或者是间隔一段时间就要执行的任务. 在这种情况下,使用celery就是一个很好的选择.   cele ...

  3. django+celery+redis实现运行定时任务

    0.目的 在开发项目中,经常有一些操作时间比较长(生产环境中超过了nginx的timeout时间),或者是间隔一段时间就要执行的任务. 在这种情况下,使用celery就是一个很好的选择.   cele ...

  4. Django+Celery+redis kombu.exceptions.EncodeError:Object of type is not JSON serializable报错

    在本文中例子中遇到问题的各种开发版本如下: Python3.6.8 Django==2.2 celery==4.4.0 kombu==4.6.7 redis==3.3.0 大概的报错如下截图: 是在开 ...

  5. django celery redis简单测试

    希望在下一版中,能用这个小芹菜,来实现异步的多任务并行哈. 安装REDIS之类的不表,只说在DJANGO当中要注意配置的事项. 0,安装插件 yum install redis-server pip ...

  6. python用Django+Celery+Redis 监视程序(一)

    C盘创建一个目录就叫DjangoDemo,然后开始在该目录下操作. 1.新建Django工程与应用 运行pip install django 安装django 这里我们建一个名为demo的项目和hom ...

  7. 使用django + celery + redis 异步发送邮件

    参考:http://blog.csdn.net/Ricky110/article/details/77205291 环境: centos7  +  python3.6.1 + django2.0.1  ...

  8. Django+Celery+Redis实现异步任务(发送邮件)

    安装如下依赖库 pip install Celery pip install django-celery pip install django-redis 还要安装本地的Redis服务 setting ...

  9. Django Celery Redis 异步执行任务demo实例

    一.windows中安装redis 安装过程见 <在windows x64上部署使用Redis> 二.环境准备 requirements.txt Django==1.10.5 celery ...

  10. django+celery+redis环境配置

    celery是python开发的分布式任务调度模块 Celery本身不含消息服务,它使用第三方消息服务来传递任务,目前,celery支持的消息服务有RabbitMQ,redis甚至是数据库,redis ...

随机推荐

  1. 仿flash运动框架

    github地址: [https://github.com/linxd5/pictureShow] PS: 新建一个github项目很简单,只要new一个repo,后面按照提示做就可以了~ 项目思路: ...

  2. LCTF (easyeasy-200)

    首先安装,看看app是什么样的. 有点奇怪,没有点击确定的按钮.然后拖到JEB反编译. 要求输入的字符串的长度要在35-39之间(包括边界值),然后会调用Format().form函数.如下图. 可以 ...

  3. Python爬虫学习==>第十章:使用Requests+正则表达式爬取猫眼电影

    学习目的: 通过一个一个简单的爬虫应用,初窥门径. 正式步骤 Step1:流程框架 抓取单页内容:利用requests请求目标站点,得到单个页面的html代码,返回结果: 正则表达式分析:根据html ...

  4. python-Web-django-qq扫码登陆

    1.建路由 2.写qq登录的a链接 3 在控制器的loginQq的方法:拼接url,跳转到这个url: 去:https://graph.qq.com/oauth2.0/authorize?respon ...

  5. 【HANA系列】SAP HANA SQL获取字符串长度

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[HANA系列]SAP HANA SQL获取字符 ...

  6. 【机器学习】Learning to Rank 简介

    Learning to Rank 简介 去年实习时,因为项目需要,接触了一下Learning to Rank(以下简称L2R),感觉很有意思,也有很大的应用价值.L2R将机器学习的技术很好的应用到了排 ...

  7. LINQ查询表达式详解(2)——查询表达式的转换

    简介 C#在执行LINQ查询表达式的时候,并不会指定其执行语义,而是将查询表达式转换为遵循查询表达式模式的方法的调用.具体而言,查询表达式将转换为以下名称的调用:Where.Select.Select ...

  8. 【转帖】超能课堂(186) CPU中的那些指令集都有什么用?

    超能课堂(186)CPU中的那些指令集都有什么用? https://www.expreview.com/68615.html 不明觉厉 开始的地方 第一大类:基础运算类x86.x86-64及EM64T ...

  9. Python 入门 之 反射

    Python 入门 之 反射 1.反射 : (自省) ​ 反射主要是指程序可以访问.检测和修改它本身状态或行为的一种能力(自省). Python面向对象中的反射:通过字符串的形式操作对象的相关属性.P ...

  10. Spring 中的bean 是线程安全的吗?

    结论: 不是线程安全的 Spring容器中的Bean是否线程安全,容器本身并没有提供Bean的线程安全策略,因此可以说Spring容器中的Bean本身不具备线程安全的特性,但是具体还是要结合具体sco ...