配置celery

celery文档

英⽂⽂档:https://docs.celeryproject.org/en/stable/userguide/configuration.html?highlight=beat_
schedule#beat-settings-celery-beat

中⽂⽂档:https://www.celerycn.io/ru-men/celery-jin-jie-shi-yong

安装包要求

pip3 install Django==2.2
pip3 install celery==4.4.7
pip3 install redis==3.5.3

项目配置

创建跟项目路径同级 celery_task⽂件夹专⻔来存储celery任务

1. 创建main.py来作为celery的启动⽂件,并配置celery

from celery import Celery
import os,sys
import django
from datetime import timedelta
# # 1.添加django项⽬根路径
CELERY_BASE_DIR = os.path.dirname(os.path.abspath(__file__))
sys.path.insert(0, os.path.join(CELERY_BASE_DIR, '../opwf'))
# 2.添加django环境
os.environ.setdefault("DJANGO_SETTINGS_MODULE","opwf.settings")
django.setup() # 读取配置
# 3.celery基本配置
app = Celery('mycelery',
 broker='redis://localhost:6379/14',
 backend='redis://localhost:6379/15',
 include=['celery_task.tasks',
 'celery_task.tasks2',
 ])
# 4.实例化时可以添加下⾯这个属性
app.conf.update(
 result_expires=3600, #执⾏结果放到redis⾥,⼀个⼩时没⼈取就丢弃
)
# 5.配置定时任务:每5秒钟执⾏ 调⽤⼀次celery_pro下tasks.py⽂件中的add函数
app.conf.beat_schedule = {
 'add-every-5-seconds': {
 'task': 'tasks.test_task_crontab',
 'schedule': timedelta(seconds=5),
 'args': (16, 16)
 },
}
# 6.添加时区配置
app.conf.timezone = 'UTC'
if __name__ == '__main__':
 app.start()

2 . 创建tasks.py来定义异步任务

from .main import app #从当前⽬录导⼊app
import os,sys
from .main import CELERY_BASE_DIR
# 1.test_task_crontab测试定时任务
@app.task
def test_task_crontab(x,y):
 # 添加django项⽬路径
 # sys.path.insert(0, os.path.join(CELERY_BASE_DIR, '../opwf'))
 from utils.rl_sms import test_crontab
 res = test_crontab(x, y)
 print(x+y)
 return x + y
# 2.测试异步发送邮件
@app.task(bind=True)
def send_sms_code(self, mobile, datas):
 sys.path.insert(0, os.path.join(CELERY_BASE_DIR, '../opwf'))
 # 在⽅法中导包
 from utils.rl_sms import send_message
 # time.sleep(5)
 try:
 # ⽤ res 接收发送结果, 成功是:0, 失败是:-1
 res = send_message(mobile, datas)
 except Exception as e:
 res = '-1'
 if res == '-1':
 # 如果发送结果是 -1 就重试.
 self.retry(countdown=5, max_retries=3, exc=Exception('短信发送失败'))

3.utils的rl_sms.py封装的公⽤⽅法

from ronglian_sms_sdk import SmsSDK
from user.models import User
accId = '8a216da8747ac98201749c0de38723b7'
accToken = '86072b540b4648229b27400414150ef2'
appId = '8a216da8747ac98201749c0de45123be'
def send_message(phone, datas):
 user = User.objects.all()[0]
 print(user.username, '%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%')
 sdk = SmsSDK(accId, accToken, appId)
 tid = '1' # 测试模板id为: 1. 内容为: 【云通讯】您的验证码是{1},请于{2}分钟内正确输
⼊。
 # mobile = '13303479527'
 # datas = ('666777', '5') # 模板中的参数按照位置传递
 # resp = sdk.sendMessage(tid, phone, datas)
 print("##########################################")
 print('执⾏了这个⽅法 send_message')
 return ''
from workorder.models import SubOrder
def test_crontab(x,y):
 # need_approve = SubOrder.objects.filter(suborder_status='1')
 print('############### 执⾏test_crontab测试任务 #############')
 print(x+y)
 print('############### 邮件审批超时提醒 #############')

4.在views.py⾥使⽤异步任务来处理函数

import sys,os
from opwf.settings import BASE_DIR
from django.http.response import JsonResponse
# Create your views here.
def test(request):
 print(BASE_DIR)
 #添加总⽂件opwf_project⽂件夹为新的导包路径,将celery_task中的⽂件导⼊
 sys.path.insert(0, os.path.join(BASE_DIR, '../../opwf_project'))
 print(sys.path)
 
 #导⼊celery_task⽂件中的异步任务
 from celery_task.tasks import test_task_crontab
 #异步任务的调⽤
 test_task_crontab.delay(10,20)
 
 return JsonResponse({"code":200})

1.管理celery任务

celery -A celery_task.main worker -l INFO # 单线程
celery multi start w1 w2 -A celery_task.main -l info #⼀次性启动w1,w2两个
worker
celery -A celery_task.main status #查看当前有哪些worker在
运⾏
celery multi stop w1 w2 -A celery_task.main #停⽌w1,w2两个worker
# 1.项⽬中启动celery worker
celery multi start celery_task -A celery_task -l debug --autoscale=50,10 
# celery并发数:最多50个,最少5个
# 2.在项⽬中关闭celery worker
ps auxww|grep "celery worker"|grep -v grep|awk '{print $2}'|xargs kill -9 
# 关闭所有celery进程

2.django_celery_beat管理

# 1.普通测试启动celery beat
celery -A celery_task.main beat -l info
# 2.在项⽬中后台启动celery beat
celery -A celery_task.main beat -l debug >> /aaa/Scheduler.log 2>&1 &
# 3.停⽌celery beat
ps -ef | grep -E "celery -A celery_test beat" | grep -v grep| awk '{print $2}'
| xargs kill -TERM &> /dev/null # 杀死⼼跳所有进程
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值