博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
RabbitMQ Exchange中的fanout类型
阅读量:6336 次
发布时间:2019-06-22

本文共 2127 字,大约阅读时间需要 7 分钟。

fanout 多播

在之前都是使用direct直连类型的交换机,通过routingkey来决定把消息推到哪个queue中。

而fanout则是把拿到消息推到与之绑定的所有queue中。

分析业务,怎样的场景需要它呢?某个用户注册了网站的用户,一般我们需要发送短信和邮件通知,莫非要在同一个consumer中把这两件事都做了?这不符合单一职责,可是发送的消息是一样的,只是方式不一样。要使用两种routingkey都发送一次?这显然也不是我们想要的。所以fanout出现了

fanout类型的exchange会把消息推到所有的queue中,所以不需要指定routingkey,指定了也没用!

下面通过代码来看

这里有两种需求,发短信与发邮件

//创建返回一个新的频道 using (var channel = RabbitMqHelper.GetConnection().CreateModel()){       //发布一个消息        var msg = Encoding.UTF8.GetBytes($"二狗子");        //不需要指定routingkey,指定了也没用.因为交换机是fanout类型        channel.BasicPublish("fanoutExchange", routingKey: string.Empty, basicProperties: null, body: msg);        Console.Write("发布成功!");}       Console.ReadKey();

这里是consumer部分的代码

bool flag = true;            string pattern = "";            while (flag)            {                Console.WriteLine("请选择Ccnsumer模式  1(发短信)/2(发邮件)");                pattern = Console.ReadLine();                if (pattern == "1" || pattern == "2")                    flag = false;                else                    Console.Write("请做出正确的选择");            }            using (var channel = RabbitMqHelper.GetConnection().CreateModel())            {                //声明交换机 Fanout模式                channel.ExchangeDeclare("fanoutExchange", ExchangeType.Fanout, true, false, null);                //根据声明使用的队列                var queueName = pattern == "1" ? "sms" : "emai";                channel.QueueDeclare(queueName, true, false, false, null);                //进行绑定                channel.QueueBind(queueName, "fanoutExchange", string.Empty, null);                //创建consumbers                var consumer = new EventingBasicConsumer(channel);                consumer.Received += (sender, e) =>                {                    var msg = Encoding.UTF8.GetString(e.Body);                    var action = (pattern == "1" ? "发短信" : "发邮件");                    Console.WriteLine($"给{msg}{action}");                };                //进行消费                channel.BasicConsume(queueName, true, consumer);                Console.ReadKey();            }

 

下面把程序运行起来,不同的consumer进行了不同的消费

转载于:https://www.cnblogs.com/LiangSW/p/6195836.html

你可能感兴趣的文章
【Signals and Systems】 SYLLABUS
查看>>
RH135-2-command-line-interface
查看>>
浅谈OS
查看>>
mac下开启docker API远程调用
查看>>
tar 命令的详解
查看>>
Cisco路由器安全配置
查看>>
第十次作业
查看>>
给定一个字符串s,返回去掉子串"mi"后的字符串。
查看>>
Nginx 外的另一选择,轻量级开源 Web 服务器 Tengine 发布新版本
查看>>
Wrod中超链接的一些技巧
查看>>
IP_VFR-4-FRAG_TABLE_OVERFLOW【cisco设备报错】碎片***
查看>>
Codeforces Round #256 (Div. 2) D. Multiplication Table 【二分】
查看>>
ARM汇编指令格式
查看>>
HDU-2044-一只小蜜蜂
查看>>
HDU-1394-Minimum Inversion Number
查看>>
df -h 卡住
查看>>
[转] createObjectURL方法 实现本地图片预览
查看>>
JavaScript—DOM编程核心.
查看>>
JavaScript碎片
查看>>
Bootstrap-下拉菜单
查看>>