当前位置: 首页 > news >正文

Celery 中,广播模式可以通过使用 RabbitMQ 的 fanout 交换机来实现

这里写自定义目录标题

  • 设置 Django 的 settings 模块
  • 从 Django 的 settings 文件中加载 Celery 配置
  • 自动发现任务
  • 使 Celery 实例可用
  • 配置 Celery 的任务路由

在 Celery 中,广播模式可以通过使用 RabbitMQ 的 fanout 交换机来实现。fanout 交换机会将消息广播到所有绑定到它的队列中。我们可以使用这种模式来让 Celery 在多个队列中处理相同的消息。

项目结构
假设你的 Django 项目结构如下:

myproject/
├── myapp/
│ ├── init.py
│ ├── tasks.py
│ ├── views.py
├── myproject/
│ ├── init.py
│ ├── settings.py
│ ├── urls.py
├── manage.py
├── celery.py
设置 Celery
创建 celery.py 配置文件:

在 myproject/celery.py 文件中配置 Celery:

python
from future import absolute_import, unicode_literals
import os
from celery import Celery

设置 Django 的 settings 模块

os.environ.setdefault(‘DJANGO_SETTINGS_MODULE’, ‘myproject.settings’)

app = Celery(‘myproject’)

从 Django 的 settings 文件中加载 Celery 配置

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

自动发现任务

app.autodiscover_tasks()
init.py 中加载 Celery:

在 myproject/init.py 中确保 Celery 被加载:

python
from future import absolute_import, unicode_literals

使 Celery 实例可用

from .celery import app as celery_app

all = (‘celery_app’,)
配置 Django 设置:

在 myproject/settings.py 中添加 Celery 配置:

python
CELERY_BROKER_URL = ‘amqp://localhost’
CELERY_RESULT_BACKEND = ‘rpc://’
CELERY_ACCEPT_CONTENT = [‘json’]
CELERY_TASK_SERIALIZER = ‘json’
CELERY_RESULT_SERIALIZER = ‘json’

配置 Celery 的任务路由

CELERY_ROUTES = {
‘myapp.tasks.process_message’: {
‘exchange’: ‘broadcast_exchange’,
‘exchange_type’: ‘fanout’,
‘routing_key’: ‘broadcast’,
},
}
创建任务
定义任务:

在 myapp/tasks.py 中定义任务:

python
from celery import shared_task

@shared_task
def process_message(message):
# 处理消息
print(f"Processing message: {message}")
# 实际处理消息的代码
设置广播模式
创建一个任务来广播消息:

在 myapp/tasks.py 中定义一个任务来广播消息:

python
from celery import Celery

app = Celery(‘myproject’)

@app.task
def broadcast_message(message):
# 创建一个任务并广播
process_message.apply_async(args=[message], exchange=‘broadcast_exchange’, routing_key=‘broadcast’)
配置 Celery 任务队列:

在 myproject/settings.py 中添加广播队列的配置:

python
CELERY_QUEUES = {
‘broadcast_queue_1’: {
‘exchange’: ‘broadcast_exchange’,
‘exchange_type’: ‘fanout’,
‘routing_key’: ‘broadcast’,
},
‘broadcast_queue_2’: {
‘exchange’: ‘broadcast_exchange’,
‘exchange_type’: ‘fanout’,
‘routing_key’: ‘broadcast’,
},
}
使用任务
在视图中调用任务:

在 myapp/views.py 中,你可以调用 broadcast_message 任务:

python
from django.http import HttpResponse
from .tasks import broadcast_message

def trigger_broadcast(request):
message = “This is a broadcast message”
broadcast_message.delay(message)
return HttpResponse(“Broadcast message is being processed.”)
更新 URL 配置:

在 myproject/urls.py 中添加一个 URL 路由来触发广播任务:

python
from django.urls import path
from myapp.views import trigger_broadcast

urlpatterns = [
path(‘broadcast/’, trigger_broadcast, name=‘trigger_broadcast’),
]
启动 Celery Worker
在你的项目根目录下启动两个 Celery worker,分别监听不同的队列:

bash
celery -A myproject worker -Q broadcast_queue_1 --loglevel=info
celery -A myproject worker -Q broadcast_queue_2 --loglevel=info
运行 Django 服务器
在另一个终端中启动 Django 服务器:

bash
python manage.py runserver
结果
访问 http://localhost:8000/broadcast/ 将触发广播消息任务。Celery 会将消息广播到两个不同的队列 (broadcast_queue_1 和 broadcast_queue_2),这两个队列分别由两个不同的 Celery worker 进程处理。

这样,你就实现了一个广播模式,在多个队列中处理相同的消息。

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • MFC工控项目实例之七点击下拉菜单弹出对话框
  • WHAT - 通过 react-use 源码学习 React(State 篇)
  • 打卡52天------图论(应用题)
  • 钉钉群消息提醒
  • Python -- GUI图形界面编程—GUI编程实例 博主也在持续学习中[ 持续更新中!!! 欢迎白嫖 ]
  • Python编程进阶题
  • centos彻底卸载docker服务
  • [笔记]基于小波分析的基频识别
  • 前端:html+css:伪类画箭头(实心)
  • 一般图最大权匹配
  • 前端面试——什么是原型和原型链
  • 这个暑假作业有点特别,帮100位老人开启这个功能
  • 一个很大的文件,文件的每一行是一个很大的数字,如果给你一个单机,内存比较小,存不了这么大的文件,但是硬盘是无限大的,如何对文件做一个排序输出
  • K8S部署MySQL5.7的主从服务
  • MFC程序设计(三)常用复杂控件的使用
  • hadoop入门学习教程--DKHadoop完整安装步骤
  • iOS高仿微信项目、阴影圆角渐变色效果、卡片动画、波浪动画、路由框架等源码...
  • JS实现简单的MVC模式开发小游戏
  • Mysql优化
  • React系列之 Redux 架构模式
  • spring cloud gateway 源码解析(4)跨域问题处理
  • 开发了一款写作软件(OSX,Windows),附带Electron开发指南
  • 如何在 Tornado 中实现 Middleware
  • 入口文件开始,分析Vue源码实现
  • 实战|智能家居行业移动应用性能分析
  • TPG领衔财团投资轻奢珠宝品牌APM Monaco
  • 支付宝花15年解决的这个问题,顶得上做出十个支付宝 ...
  • ​LeetCode解法汇总2304. 网格中的最小路径代价
  • ​软考-高级-系统架构设计师教程(清华第2版)【第12章 信息系统架构设计理论与实践(P420~465)-思维导图】​
  • #设计模式#4.6 Flyweight(享元) 对象结构型模式
  • (PWM呼吸灯)合泰开发板HT66F2390-----点灯大师
  • (python)数据结构---字典
  • (solr系列:一)使用tomcat部署solr服务
  • (办公)springboot配置aop处理请求.
  • (附源码)springboot太原学院贫困生申请管理系统 毕业设计 101517
  • (附源码)ssm教材管理系统 毕业设计 011229
  • (黑马点评)二、短信登录功能实现
  • (论文阅读26/100)Weakly-supervised learning with convolutional neural networks
  • (论文阅读31/100)Stacked hourglass networks for human pose estimation
  • (每日持续更新)信息系统项目管理(第四版)(高级项目管理)考试重点整理第3章 信息系统治理(一)
  • (微服务实战)预付卡平台支付交易系统卡充值业务流程设计
  • (一)kafka实战——kafka源码编译启动
  • (转)甲方乙方——赵民谈找工作
  • (转载)CentOS查看系统信息|CentOS查看命令
  • (自适应手机端)响应式新闻博客知识类pbootcms网站模板 自媒体运营博客网站源码下载
  • .FileZilla的使用和主动模式被动模式介绍
  • .NET Core 中的路径问题
  • .NET 漏洞分析 | 某ERP系统存在SQL注入
  • .NET/C# 异常处理:写一个空的 try 块代码,而把重要代码写到 finally 中(Constrained Execution Regions)
  • .net6 core Worker Service项目,使用Exchange Web Services (EWS) 分页获取电子邮件收件箱列表,邮件信息字段
  • .Net8 Blazor 尝鲜
  • .NetCore Flurl.Http 升级到4.0后 https 无法建立SSL连接
  • .netcore如何运行环境安装到Linux服务器
  • .net对接阿里云CSB服务
  • @Transactional 详解