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

C#使用RabbitMQ-3_发布订阅模式(扇形交换机)

简介

发布订阅模式允许一个生产者向多个消费者发送消息。在RabbitMQ中实现发布订阅模式通常涉及以下几个关键组件:

  1. 生产者:负责生产并发送消息到RabbitMQ的Exchange(路由器)。
  2. Exchange:作为消息的中转站,根据不同的规则将消息路由到一个或多个队列。
  3. 队列:存储消息的缓冲区,每个消费者有自己的独立队列。
  4. 消费者:从自己的队列中接收并消费消息。

在这种模式下,生产者发送的消息不是直接发送到特定的队列,而是发送给Exchange。Exchange根据配置的规则决定如何处理这些消息。例如,它可以将消息路由到一个特定的队列,也可以将消息路由到多个队列,或者在某些情况下废弃消息。

在实际应用中,发布订阅模式常用于构建实时通信系统、通知服务、日志系统等场景,其中多个消费者需要接收来自同一生产者的消息。这种模式的优势在于能够实现一对多的通信,使得消息的分发更加灵活和高效。

 生产者代码

在前面的模式中,我们使用了channel.QueueDeclare()来声明队列。这里不需要了

channel.QueueDeclare("hello", true, false, false, null);

在发布订阅模式中,生产者只需要将消息发送到交换机上,然后由交换机根据绑定规则将消息路由到一个或多个队列中。消费者则可以从自己的队列中获取并处理这些消息。

因此,我们这里只声明一个扇形交换机,并将消息发布到该交换机上即可。而具体的队列声明和绑定操作可以在消费者端进行。

在前面的第一章和第二章中,我们都没有声明交换机,这是因为RabbitMQ中有一个默认的交换机,称为空字符串名称的默认交换机。当生产者发送消息但没有指定交换机时,消息会被发送到这个默认交换机。同样,当创建队列但没有指定队列与交换机的绑定关系时,队列会自动绑定到默认交换机上。RabbitMQ提供了几种内置的交换机类型,如直接交换(direct)、扇形交换(fanout)、主题交换(topic)和头交换(headers)等,以满足不同的业务场景需求。

class MyClass
{public static void Main(string[] args){var factory = new ConnectionFactory();factory.HostName = "localhost"; //RabbitMQ服务在本地运行factory.UserName = "guest"; //用户名factory.Password = "guest"; //密码//创建连接using (var connection = factory.CreateConnection()){//创建通道using (var channel = connection.CreateModel()){//声明了一个扇形交换机(fanout exchange),命名为"hello"channel.ExchangeDeclare("hello", "fanout");string msg;Console.WriteLine("请输入要发送的消息内容:");while (!string.IsNullOrEmpty(msg = Console.ReadLine())){var body = Encoding.UTF8.GetBytes(msg);channel.BasicPublish("hello", "", null, body); //开始传递Console.WriteLine("已发送: {0}", msg);}}}}
}

消费者代码

我们通过channel.QueueDeclare().QueueName;声明一个新的队列,如果这个方法声明队列,RabbitMQ会自动为你生成一个独一无二的队列名称

var queueName = channel.QueueDeclare().QueueName;
channel.QueueBind(queueName, "hello", "");

然后将队列的名称赋值给变量queueName。将该队列绑定到之前声明的扇形交换机hello上,使用空字符串作为路由键。每次运行这个项目时,都会创建一个新的队列并将其绑定到交换机上。这样,多个消费者可以同时连接到同一个交换机,并从不同的队列中接收消息。

class MyClass
{static void Main(string[] args){//创建连接工厂var factory = new ConnectionFactory();factory.HostName = "localhost";factory.UserName = "guest";factory.Password = "guest";//创建连接using (var connection = factory.CreateConnection()){//创建通道using (var channel = connection.CreateModel()){//声明了一个扇形交换机(fanout exchange),命名为"hello"channel.ExchangeDeclare("hello", "fanout");//声明一个新的队列,并将这个队列的名称赋值给变量 queueNamevar queueName = channel.QueueDeclare().QueueName;channel.QueueBind(queueName, "hello", "");//事件的基本消费者var consumer = new EventingBasicConsumer(channel);consumer.Received += (model, ea) =>{var body = ea.Body.ToArray();var message = Encoding.UTF8.GetString(body);Console.WriteLine("已接收: {0}", message);};channel.BasicConsume(queueName, true, consumer);Console.ReadKey();}}}
}

代码演示

和我前面文章的步骤一样,将消费者先进行发布打包,双击.exe文件运行多次项目。

我们前面提到的使用channel.QueueDeclare().QueueName;声明一个新的队列,在RabbitMQ管理界面可以看到有三个自动生成名称的队列。

然后我们启动生产者,并随机发送几条消息

再回到消费者,我们运行的三个消费端都同时的收到了消息!

http://www.lryc.cn/news/291271.html

相关文章:

  • 区块链游戏解说:什么是 SecondLive
  • 构建基于Flask的跑腿外卖小程序
  • 【算法】Partitioning the Array(数论)
  • ASP.NET Core 7 Web 使用Session
  • (1)SpringBoot学习——芋道源码
  • 宏景eHR FrCodeAddTreeServlet SQL注入漏洞复现
  • STM32——I2C
  • 笔记本从零安装ubuntu server系统+环境配置
  • SQL 快速参考手册
  • Linux/Windows系统无法git clone解决办法
  • 【算法与数据结构】198、213、337LeetCode打家劫舍I, II, III
  • React、React Router、JSX 简单入门快速上手
  • 从 0 开始搭建 React 框架
  • 网站地址怎么改成HTTPS?
  • Blender教程(基础)-面的细分与删除、挤出选区-07
  • QT自制软键盘 最完美、最简单、支持中文输入(二)
  • SpringCloud_学习笔记_1
  • 容器算法迭代器初识
  • 瑞_力扣LeetCode_二叉搜索树相关题
  • python爬虫爬取网站
  • c# Get方式调用WebAPI,WebService等接口
  • 银行数据仓库体系实践(11)--数据仓库开发管理系统及开发流程
  • 微信小程序引导用户打开定位授权通用模版
  • JVM篇----第十篇
  • DevSecOps 参考模型介绍
  • 什么是okhttp?
  • R语言基础学习-02 (此语言用途小众 用于数学 生物领域 基因分析)
  • CTF-WEB的入门真题讲解
  • 【C项目】顺序表
  • 【Docker】在Windows下使用Docker Desktop创建nginx容器并访问默认网站