电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

Django中使用Celery的方法步驟

瀏覽:150日期:2024-09-15 13:55:26

(一)、概述

Celery是一個簡單、靈活和可靠的基于多任務的分布式系統(tǒng),為運營提供用于維護此系統(tǒng)的工具。專注于實時處理的任務隊列,同時也支持任務的調度。執(zhí)行單元為任務(task),利用多線程這些任務可以被并發(fā)的在單個或多個職程(worker)上運行。

Celery通過消息機制通信,通常通過中間人(broker)來分配和調節(jié)客戶端與職程服務器(worker)之間的通信。客戶端發(fā)送一條消息,中間人把消息分配給一個職程,最后由職程來負責執(zhí)行此任務。

Celery可以有多個職程和中間人,這樣提高了高可用性和橫向的擴展能力

Celery由python語言開發(fā),但是該協(xié)議可以用任何語言拉力實現(xiàn),例如:Django中的Celery、node中的node-celery和php中的celery-php

(二)、Django中使用Celery的流程與配置

導入Celery:pip3 install Celery

在 與項目同名的目錄下 創(chuàng)建celery.py文件,特別注意:項目同名的目錄下

復制內容到該文件

修改兩處內容

os.environ.setdefault(’DJANGO_SETTINGS_MODULE’, ’proj.settings’)中的proj改為項目名 app = Celery(’pro’)中的pro改為項目名

import osfrom celery import Celery# set the default Django settings module for the ’celery’ program.os.environ.setdefault(’DJANGO_SETTINGS_MODULE’, ’proj.settings’)app = Celery(’pro’)# Using a string here means the worker doesn’t have to serialize# the configuration object to child processes.# - namespace=’CELERY’ means all celery-related configuration keys# should have a `CELERY_` prefix.app.config_from_object(’django.conf:settings’, namespace=’CELERY’)# Load task modules from all registered Django app configs.app.autodiscover_tasks()@app.task(bind=True)def debug_task(self): print(f’Request: {self.request!r}’)

在 與項目同名的目錄下 的__init__.py文件中添加內容

# This will make sure the app is always imported when# Django starts so that shared_task will use this app.from .celery import app as celery_app__all__ = (’celery_app’,)

在settings.py文件中添加配置

CELERY_BROKER_URL:中間人url,可以配置redis或者RabbitMQ CELERY_RESULT_BACKEND:返回結果的存儲地址 CELERY_ACCEPT_CONTENT:接收內容的格式,分為兩種:json和msgpack。msgpack比json格式的數(shù)據(jù)體積更小,傳輸速度更快。 CELERY_TASK_SERIALIZER:任務載荷的序列化方式-->json CELERY_TIMEZONE CELERY_TASK_TRACK_STARTED:是否開啟任務跟蹤 CELERY_TASK_TIME_LIMIT:任務超時限制

# Celery配置CELERY_BROKER_URL = env('CELERY_BROKER_URL')CELERY_RESULT_BACKEND = env('CELERY_RESULT_BACKEND')CELERY_ACCEPT_CONTENT = ['json', 'msgpack']CELERY_TASK_SERIALIZER = 'json'CELERY_TIMEZONE = 'Asia/Shanghai'CELERY_TASK_TRACK_STARTED = TrueCELERY_TASK_TIME_LIMIT = 30 * 60

在app下創(chuàng)建tasks.py文件,創(chuàng)建發(fā)送消息功能,任務方法必須添加裝飾器:@shared_task

from rest_framework.response import Responsefrom rest_framework.generics import GenericAPIViewfrom time import sleepfrom celery import shared_taskclass TestView3(GenericAPIView): @classmethod @shared_task def sleep(self, duration): sleep(duration) return Response('成功', status=200)

創(chuàng)建視圖和路由

### views.pyfrom .tasks import TestView3class TestView1(GenericAPIView): def get(self, request): TestView3.sleep(10) return Response('celery實驗成功')test_view_1 = TestView1.as_view()### urls.pyfrom django.urls import pathfrom .views import ( test_view_1)urlpatterns = [ path(’celery/’, test_view_1, name='test1')]

安裝redis并啟動

啟動django項目

使用Celery命令啟動Celery服務,命令:celery -A 項目名 worker -l info,如果如下所示則為啟動成功.

celery@AppledeMacBook-Air.local v5.0.3 (singularity)Darwin-20.1.0-x86_64-i386-64bit 2020-12-05 20:52:17[config].> app: drf_email_project:0x7f84a0c4ad68.> transport: redis://127.0.0.1:6379/1%20.> results: redis://127.0.0.1:6379/2.> concurrency: 4 (prefork).> task events: OFF (enable -E to monitor tasks in this worker)[queues].> celery exchange=celery(direct) key=celery[tasks] . drf_email_project.celery.debug_task . users.tasks.sleep[2020-12-05 20:52:18,166: INFO/MainProcess] Connected to redis://127.0.0.1:6379/1%20[2020-12-05 20:52:18,179: INFO/MainProcess] mingle: searching for neighbors[2020-12-05 20:52:19,212: INFO/MainProcess] mingle: all alone[2020-12-05 20:52:19,248: WARNING/MainProcess] /Users/apple/drf-email/lib/python3.7/site-packages/celery/fixups/django.py:204: UserWarning: Using settings.DEBUG leads to a memory leak, never use this setting in production environments! leak, never use this setting in production environments!’’’)[2020-12-05 20:52:19,249: INFO/MainProces

到此這篇關于Django中使用Celery的方法步驟的文章就介紹到這了,更多相關Django使用Celery的方法步驟內容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持好吧啦網(wǎng)!

標簽: Django
相關文章:
主站蜘蛛池模板: 水热合成反应釜-防爆高压消解罐-西安常仪仪器设备有限公司 | 合肥钣金加工-安徽激光切割加工-机箱机柜加工厂家-合肥通快 | 单电机制砂机,BHS制砂机,制沙机设备,制砂机价格-正升制砂机厂家 单级/双级旋片式真空泵厂家,2xz旋片真空泵-浙江台州求精真空泵有限公司 | 青岛侦探_青岛侦探事务所_青岛劝退小三_青岛调查出轨取证公司_青岛婚外情取证-青岛探真调查事务所 | 原子吸收设备-国产分光光度计-光谱分光光度计-上海光谱仪器有限公司 | 深圳公司注册-工商注册公司-千百顺代理记账公司 | 水轮机密封网 | 水轮机密封产品研发生产厂家 | 百度爱采购运营研究社社群-店铺托管-爱采购代运营-良言多米网络公司 | 恒湿机_除湿加湿一体机_恒湿净化消毒一体机厂家-杭州英腾电器有限公司 | 河南正规膏药生产厂家-膏药贴牌-膏药代加工-修康药业集团官网 | 旅游规划_旅游策划_乡村旅游规划_景区规划设计_旅游规划设计公司-北京绿道联合旅游规划设计有限公司 | 武汉画册印刷厂家-企业画册印刷-画册设计印刷制作-宣传画册印刷公司 - 武汉泽雅印刷厂 | 新型游乐设备,360大摆锤游乐设备「诚信厂家」-山东方鑫游乐设备 新能源汽车电池软连接,铜铝复合膜柔性连接,电力母排-容发智能科技(无锡)有限公司 | 植筋胶-粘钢胶-碳纤维布-碳纤维板-环氧砂浆-加固材料生产厂家-上海巧力建筑科技有限公司 | 废气处理设备-工业除尘器-RTO-RCO-蓄热式焚烧炉厂家-江苏天达环保设备有限公司 | 消泡剂_水处理消泡剂_切削液消泡剂_涂料消泡剂_有机硅消泡剂_广州中万新材料生产厂家 | 行业分析:提及郑州火车站附近真有 特殊按摩 ?2025实地踩坑指南 新手如何避坑不踩雷 | 东莞注册公司-代办营业执照-东莞公司注册代理记账-极刻财税 | 谷梁科技| 祝融环境-地源热泵多恒系统高新技术企业,舒适生活环境缔造者! | 湖南长沙商标注册专利申请,长沙公司注册代理记账首选美创! | 耐高温电缆厂家-远洋高温电缆 | 锂电池砂磨机|石墨烯砂磨机|碳纳米管砂磨机-常州市奥能达机械设备有限公司 | 气动机械手-搬运机械手-气动助力机械手-山东精瑞自动化设备有限公司 | 铝箔袋,铝箔袋厂家,东莞铝箔袋,防静电铝箔袋,防静电屏蔽袋,防静电真空袋,真空袋-东莞铭晋让您的产品与众不同 | 最新电影-好看的电视剧大全-朝夕电影网 | 凝胶成像仪,化学发光凝胶成像系统,凝胶成像分析系统-上海培清科技有限公司 | 菏泽商标注册_菏泽版权登记_商标申请代理_菏泽商标注册去哪里 | 保健品OEM贴牌代加工厂家_德州健之源| 东莞市天进机械有限公司-钉箱机-粘箱机-糊箱机-打钉机认准东莞天进机械-厂家直供更放心! | 赛默飞Thermo veritiproPCR仪|ProFlex3 x 32PCR系统|Countess3细胞计数仪|371|3111二氧化碳培养箱|Mirco17R|Mirco21R离心机|仟诺生物 | 云南外加剂,云南速凝剂,云南外加剂代加工-普洱澜湄新材料科技有限公司 | 万家财经_财经新闻_在线财经资讯网 | 深圳货架厂家_金丽声精品货架_广东金丽声展示设备有限公司官网 | crm客户关系管理系统,销售管理系统,crm系统,在线crm,移动crm系统 - 爱客crm | 郑州墨香品牌设计公司|品牌全案VI设计公司 | elisa试剂盒价格-酶联免疫试剂盒-猪elisa试剂盒-上海恒远生物科技有限公司 | 网架支座@球铰支座@钢结构支座@成品支座厂家@万向滑动支座_桥兴工程橡胶有限公司 | 淬火设备-钎焊机-熔炼炉-中频炉-锻造炉-感应加热电源-退火机-热处理设备-优造节能 | 衬塑管道_衬四氟管道厂家-淄博恒固化工设备有限公司 | 艾默生变频器,艾默生ct,变频器,ct驱动器,广州艾默生变频器,供水专用变频器,风机变频器,电梯变频器,艾默生变频器代理-广州市盟雄贸易有限公司官方网站-艾默生变频器应用解决方案服务商 |