django使用celery搭配redis配置定时任务
已经安装环境:
Python3.6
django==2.1.8(用2.2.2需要升级sqlite3)
项目名称:ceshiproject APP名称:ceshi
第一步:centos7下首先安装redis程序
wget http://download.redis.io/releases/redis-5.0.5.tar.gz 或者 到官网https://redis.io/download 查看教程并下载
tar xzf redis-5.0.5.tar.gz
yum install gcc gcc-c++ #安装一下依赖,如果有省略
cd redis-5.0.5
make MALLOC=libc
cd src && make install
---------到此安装完成---------------
cd redis-5.0.5 #进入安装目录
./redis-server #启动redis
./redis-cli #可进入redis命令模式,一般用不上
第二步:安装django-celery==3.2.2,并在APP中添加加 'djcelery' (注意:如果超过3.2.2版本程序会报错:TypeError: can only concatenate list (not "tuple") to list)
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'ceshi',
'djcelery'
]
第三步:在项目ceshiproject下,新建配置文件celeryconfig.py,内容如下
# -*- coding:utf-8 -*-
import djcelery
djcelery.setup_loader()
from datetime import timedelta #设置任务运行时,使用的队列,以防造成定时,跟定期拥堵
CELERY_QUEUES = {
'beat_task1':{
'exchange':'beat_task1',
'exchange_type':'direct',
'binding_key':'beat_task1'
},
'work_queue':{
'exchange':'work_queue',
'exchange_type':'direct',
'binding_key':'work_queue'
}
} #设置默认使用的队列
CELERY_DEFAULT_QUEUE = 'work_queue' #导入任务
CELERY_IMPORTS=(
'ceshi.task1',
) #有些情况下防止死锁
CELERY_FORCE_EXECV = True #设置并发的worker数量,根据cpu核心数量来定
CELERY_CONCURRENCY = 4 #任务失败,可以允许重试
CELERY_ACKS_LATE = True #设置每一个worker可以执行多少个任务后销毁,防止内存泄漏
CELERY_MAX_TASKS_PER_CHILD = 100 #单个任务最大的运行时间,这边设置6分钟
CELERY_TASK_TIME_LIMIT = 12 * 30 # 定时任务
CELERYBEAT_SCHEDULE = {
'task1': {
'task': 'ceshi_task', # 任务名称
'schedule': timedelta(seconds=10), # 时间周期
'options': {
'queue': 'beat_task1' # 消息队列
}
},
# 'task2': {
# 'task': 'update-db', # 任务名称
# # 'schedule': crontab(minute=0, hour=0), # 每天凌晨执行一次
# 'schedule': timedelta(seconds=10), #
# 'options': {
# 'queue': 'beat_tasks'
# }
# }
}
第四步:在APP下面新建任务task1.py,内容如下:
from celery.task import Task #调用celery中的task模块
import time
class ceshitask(Task):
name = "ceshi_task"
def run(self, *args, **kwargs):
print ("start ceshi task")
time.sleep(5)
print ("args={},kwargs={}".format(args,kwargs))
print ("end task")
第五步:配置好项目跟APP的路由
项目ceshiproject路由:
from django.contrib import admin
from django.urls import path,include urlpatterns = [
path('admin/', admin.site.urls),
path('', include('ceshi.urls',namespace='ceshi')),
]
APP(ceshi)的路由
from django.urls import path
from . import views
app_name="ceshi"
urlpatterns = [
path('do/', views.do,name='do'),
]
第六步:
首先安装redis驱动:pip install redis==2.10.6
redis==2.10.6 (高版本会报错,用于django内部驱动用跟下面安装程序是不一样)
在setting.py中配置redis调用,引入项目下面的celerycofig.py
from .celeryconfig import *
BROKER_BACKEND = 'redis'
BROKER_URL = 'redis://localhost:6379/1'
CELERY_RESULT_BACKEND = 'redis://localhost:6379/2'
第七步:在views.py中引入APP下面的task1,并调用
from django.http import JsonResponse
from ceshi.task1 import ceshitask def do(request):
#执行异步任务
print ('start request')
ceshitask.delay()
print ('end request')
return JsonResponse({"result":"ok"})
第八步:开启两个终端,并在终端中(Terminal)启动celery中的worker跟定时任务beat模块,进行测试
python manage.py celery worker -l INFO #首先开启worker
python manage.py celerybeat -l INFO #开启定时任务
第九步:上面可以使用了,如果要在django中调用,进行一序列的操作,请继续往下走:
1.把django中cache用于redis
首先安装django-redis==4.10
2.把下面的内容添加到django的settings.py中(redis默认不能超过16,如果
redis://127.0.0.1:6379/10 设置为17会出现:redis.exceptions.ResponseError: DB index is out of range
)
CACHES = {
"default": {
"BACKEND": "django_redis.cache.RedisCache",
# 把这里缓存你的redis服务器ip和port
"LOCATION": "redis://127.0.0.1:6379/10",
"OPTIONS": {
"CLIENT_CLASS": "django_redis.client.DefaultClient",
}
}
}
# 3.设置redis存储django的session信息
SESSION_ENGINE = "django.contrib.sessions.backends.cache"
SESSION_CACHE_ALIAS = "default"
3.可以在task任务,通过下面命令设置redis,(注意:设置cache时候参数加None,即cache永久不失效)
from django.core.cache import cache
class ceshitask(Task):
name = "ceshi_task"
def run(self, *args, **kwargs):
cache.set("start-ceshi-task",值, None)
return "ceshi....."
4.在views中调用
from django.shortcuts import render,HttpResponse
from django.core.cache import cache
import json def num_recode(request):
count = cache.get("start-ceshi-task")
print(json.loads(count))
return HttpResponse(count)
django使用celery搭配redis配置定时任务的更多相关文章
- Django + Celery 实现动态配置定时任务
哈喽,今天给大家分享一篇Django+Celery实现动态配置定时任务,因为最近也是无意间看到一位大佬关于这块的文章,然后自己觉得不错,也想学习写一下,然后最终实现功能是在前端页面统一管理计划任务,大 ...
- Django 使用celery任务队列的配置
celery 情景:用户发起request,并等待response返回.在本些views中,可能需要执行一段耗时的程序,那么用户就会等待很长时间,造成不好的用户体验,比如发送邮件.手机验证码等. 使用 ...
- 基于Django+celery二次开发动态配置定时任务 ( 一 )
需求: 前端时间由于开发新上线一大批系统,上完之后没有配套的报表系统.监控,于是乎开发.测试.产品.运营.业务部.财务等等各个部门就跟那饥渴的饿狼一样需要 各种各样的系统数据满足他们.刚开始一天一个还 ...
- 基于Django+celery二次开发动态配置定时任务 ( 二)
一.需求 结合上一篇,使用djcelery模块开发定时任务时,定时任务的参数都保存在djcelery_periodictask表的args.kwargs字段里,并且是json格式.那么,当定时任务多了 ...
- django —— Celery实现异步和定时任务
1. 环境 python==2.7 djang==1.11.2 # 1.8, 1.9, 1.10应该都没问题 celery-with-redis==3.0 # 需要用到redis作为中间人服务(Bro ...
- Celery+python+redis异步执行定时任务
我之前的一篇文章中写了[Celery+django+redis异步执行任务] 博文:http://blog.csdn.net/apple9005/article/details/54236212 你会 ...
- celery 动态配置定时任务
How to dynamically add or remove tasks to celerybeat? · Issue #3493 · celery/celery https://github.c ...
- Django Redis配置
Django Redis配置 # Django默认不支持redis,需要第三方插件来支持 pipenv install django-redis pipenv install hiredis # 不是 ...
- Django中Celery的实现介绍(一)
Django中Celery的实现 Celery官网http://www.celeryproject.org/ 学习资料:http://docs.jinkan.org/docs/celery/ Cele ...
随机推荐
- 保护亿万数据安全,Spring有“声明式事务”绝招
摘要:点外卖时,你只需考虑如何拼单:选择出行时,你只用想好目的地:手机支付时,你只需要保证余额充足.但你不知道这些智能的背后,是数以亿计的强大数据的支持,这就是数据库的力量.那么庞大数据的背后一定会牵 ...
- noip模拟10
被打回原形了emmmmm 贴张图吧,展示一下根本不行的水平 考试经过 上来浏览一遍T1到T3,读懂题之后发现都不是很可做 T1上了想到了前缀和,往矩阵快速幂想了一下觉得不可做,半小时之后还是只会\(n ...
- tcp为什么要三次握手,tcp为什么可靠
转自 : https://www.cnblogs.com/LUO77/p/5771237.html大体看过,没有深入研究,有需要时继续看. 为什么不能两次握手:(防止已失效的连接请求又传送到服务器端, ...
- C#比较两个对象是否为同一个对象。 Visual Studio调试器指南---多线程应用程序调试(一)
两个对象是否为同一个对象:是看两个对象是否指向堆中的同一块内存. 1.使用object.ReferenceEquals() class Program { static void Main(strin ...
- 使用VC6.0开发COM组件 - 傻瓜式,不讲理论,只讲实例
1.创建一个ATL COM AppWizard工程,如图:
- xxx.pch(No such file or directory)
今天在写一个组件的Demo,发现把一个现象. 我把stdafx.h和stdafx.cpp从工程删除了(本地也被我删除了).后来又想把它加回去,就用新的工程生成这两个文件.然后拷贝过来,增加到工程. 但 ...
- Difference between trustStore and keyStore in Java - SSL
Difference between trustStore and keyStore in Java - SSL trustStore vs keyStore in Java trustStore ...
- sparksql字段类型转换
1.spark sql 计算时,一定要注意精度的问题,一般像金额之类的值,要先转换为double或者 decimal来进行计算了. 一.sql的方式:select shop_id,order_id,s ...
- IT项目经理-成长手记学习笔记
无论多难,都要记住一点,只要别人不赶你走,你就厚着脸皮待下去,这样你才有可能熬到项目成功. 项目经理要管事,更要管人. 项目计划->职责分工->确定项目范围 遇事及时处理,当场处理,处理错 ...
- Systemd Journald占用资源过多
journald占用过多磁盘空间 方法一 检查当前journal使用磁盘量 journalctl --disk-usage 清理方法可以采用按照日期清理,或者按照允许保留的容量清理,只保存2天的日志, ...