rabbitmq(二)订阅模式\路由模式\topic
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了rabbitmq(二)订阅模式\路由模式\topic相关的知识,希望对你有一定的参考价值。
参考技术A boolan autoAck = true; 时时自动确认模式:一旦rabbitmq将消息分给消费者,就会从内存中删除
缺陷 这种情况下,如果杀手正在执行的消费者,就会丢失正在处理的消息
boolan autoAck = true; 自动确认模式:一旦rabbitmq将消息分给消费者,就会从内存中删除
缺陷 这种情况下,如果杀手正在执行的消费者,就会丢失正在处理的消息
boolan autoAck = false; 手动确认模式:一旦有一个消费者挂掉,就会交付给其他消费者,rabbitmq支持消息应答。高速rabbitmq这个消息我已经处理完成,你可以删了。然后rabbitmq就会删除内存中的消息
消息应答默认展开的即 autoAck = false
ack:message acknowledgment
消息持久化
已经定义的队列不能改变持久化状态
前面都是一个消息只能被一个消费者消费,该模式可以实现一个消息发送给多个消费者
模型
特点
效果
一方面是接收生产者的消息,另一方面是向队列推送消息
匿名和非匿名
fanout(不处理路由键)
direct(处理路由键)
生产者
消费者
将路由键和某模式匹配
模型
生产者
消费者
RabbitMQ : 订阅者模式之路由模式 ( direct )
路由模式下,生产者发送消息时需要指定一个路由键(routingKey),交换机只会把消息转发给包含该路由键的队列
这里,我们改变一下声明交换机的方式.
我们通过管理后台添加一个交换机.
添加后,生产者和消费者的代码中就不需要再声明交换机了.同样,也可以通过管理后台添加队列,那么代码中也不需要声明队列了.
生产者
public class Producer { private const string ExchangeName = "test_exchange_direct"; public static void Send() { IConnection connection = ConnectionHelper.GetConnection(); IModel channel = connection.CreateModel(); string msg = "hello world "; //把消息发送到交换机,交换机再转发到包含路由键"refuge"的队列. channel.BasicPublish(ExchangeName, "refuge", null, Encoding.Default.GetBytes(msg)); Console.WriteLine($"send {msg}"); channel.Close(); connection.Close(); } }
消费者1
public class Consumer1 { private const string QueueName = "test_exchange1_queue"; private const string ExchangeName = "test_exchange_direct"; public static void Receive() { //获取连接 RabbitMQ.Client.IConnection connection = ConnectionHelper.GetConnection(); //创建通道 RabbitMQ.Client.IModel channel = connection.CreateModel(); //声明队列 channel.QueueDeclare(QueueName, false, false, false, null); //声明交换机 //channel.ExchangeDeclare(ExchangeName, "direct", false, false, null); //将队列绑定到交换机上,路由键为"wjire" channel.QueueBind(QueueName, ExchangeName, "wjire", null); //添加消费者 EventingBasicConsumer consumer = new EventingBasicConsumer(channel); //注册事件 consumer.Received += (s, e) => { byte[] bytes = e.Body; string str = Encoding.Default.GetString(bytes); Console.WriteLine("consumer1 : " + str); }; //监听队列 channel.BasicConsume(QueueName, true, "", false, false, null, consumer); } }
消费者2
public class Consumer2 { private const string QueueName = "test_exchange2_queue"; private const string ExchangeName = "test_exchange_direct"; public static void Receive() { //获取连接 RabbitMQ.Client.IConnection connection = ConnectionHelper.GetConnection(); //创建通道 RabbitMQ.Client.IModel channel = connection.CreateModel(); //声明队列 channel.QueueDeclare(QueueName, false, false, false, null); //声明交换机 //channel.ExchangeDeclare(ExchangeName, "direct", false, false, null); //将队列绑定到交换机上,该队列匹配两个路由键,"refuge"和"wjire" channel.QueueBind(QueueName, ExchangeName, "refuge", null); channel.QueueBind(QueueName, ExchangeName, "wjire", null); //添加消费者 EventingBasicConsumer consumer = new EventingBasicConsumer(channel); //注册事件 consumer.Received += (s, e) => { byte[] bytes = e.Body; string str = Encoding.Default.GetString(bytes); Console.WriteLine(" consumer2 : " + str); }; //监听队列 channel.BasicConsume(QueueName, true, "", false, false, null, consumer); } }
运行结果:
可以看到,只有消费者2消费了消息.
以上是关于rabbitmq(二)订阅模式\路由模式\topic的主要内容,如果未能解决你的问题,请参考以下文章
RabbitMQ03_Springboot整合RabbitMQ实现发布与订阅模式路由模式通配符模式
RabbitMQ03_Springboot整合RabbitMQ实现发布与订阅模式路由模式通配符模式
RabbitMQ:第三章:Springboot集成RabbitMQ(直连模式,工作队列模式,发布订阅模式,路由模式,通配符模式)
RabbitMQ4三种Exchange模式——订阅路由通配符模式
RabbitMQ : 订阅者模式之路由模式 ( direct )
RabbitMQ02_简单模式Publish/Subscribe发布与订阅模式Routing路由模式Topics通配符模式Work模式-轮询公平