消息中间件rabbitmq(3)

本文深入探讨了RabbitMQ中的Exchange概念,包括direct、topic和fanout三种类型的工作原理及应用。通过实例展示了如何创建Exchange,绑定Queue,并利用RoutingKey进行消息的精确或模糊匹配,确保消息能够正确地到达目标队列。

介绍

RabbitMq中不存在topic这个概念,不同的消费者想要消费不同的消息只有通过Exchange(交换器)来实现

Exchange类型介绍

注:1. 在针对同一个queue或者exchage时,queueDeclare消费者和生产者所有的配置都必须要保存一致,否则会抛出530的异常。   

       2.Exchange只用于Producer,RoutingKey用来绑定Exchange和Queue,这个一般在Producer这端做的。

      *3. 假如Producer把消息发到没有绑定Queue的Exchange消息会丢失!

direct类型

该类型的是默认的exchage,直接指定消息需要发送的那个队列

Exchage创建

channel.queueDeclare(QUEUE_NAME, false, false, false, null);

发送消息

channel.basicPublish("", QUEUE_NAME, null, message.getBytes("UTF-8"));

接受消息

chanel.queueDeclare(QUEUE_NAME, false, false, false, null);

Topic类型

该类型的exchange可以通过模糊匹配,使一个消费者可以消费多个queue的消息

Exchage创建

//EXCHANGE_NAME创建过后不能修改 第三个参数表示持久化
channel.exchangeDeclare(EXCHANGE_NAME, "topic",true);
//将队列,转换器,路由规则绑定(下面表示的是吧不同的两个队列绑定到同一个转换器上,但是配置不同的routeKey)
channel.queueBind(QUEUE_NAME, EXCHANGE_NAME, "*.second.*");
channel.queueBind(QUEUE_NAME+".v2", EXCHANGE_NAME, "first.second.*");

发送消息

//第二个参数表示routeKey  格式为String.String.String...(根据路由规则匹配,下面这个消息会同时发送到QUEUE_NAME和QUEUE_NAME.v2这两个队列中)
channel.basicPublish(EXCHANGE_NAME, "first.second.three", null,message.getBytes());

接受消息

channel.exchangeDeclare(EXCHANGE_NAME, "topic");
String queue = channel.queueDeclare().getQueue();
//第三个参数表示routeKey,这里不同于生产者,是可以使用* 或者 # 进行模糊匹配,即满足该表达式的queue都可以消费,比如之前设置的first.second.three在这里可以设置成first.*.*或者first.#或者 *.second.*来进行消费
channel.queueBind(queue, EXCHANGE_NAME, "first.*.*");
// 声明要关注的队列
channel.queueDeclare(queue, true, false, false, null);

Fanout类型

不处理路由键。你只需要简单的将队列绑定到交换机上。一个发送到该类型交换机的消息都会被广播到与该交换机绑定的所有队列

创建Exchange

channel.exchangeDeclare(EXCHANGE_NAME, "fanout")

发送消息

channel.basicPublish(EXCHANGE_NAME, "", null, message.getBytes());

接受消息

channel.exchangeDeclare(EXCHANGE_NAME, "fanout");
String queueName = channel.queueDeclare().getQueue();
channel.queueBind(queueName, EXCHANGE_NAME, "");

 

转载于:https://www.cnblogs.com/dengyu/p/10059444.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值