Exchange 用于接收消息,并根据路由键转发消息到所绑定的队列。
上图来源于某视频课程截图,如侵权,请联系立即删除!
从图中可以看出,Exchange 与 Queue 是通过 RoutingKye 来进行关联的,且 Exchange 与 Queue 是多对多的关系。
交换机常见属性
Name: 交换机名称
Type: 交换机类型,主要有 direct topic fanout headers
Durability: 是否需要持久化,true 表示持久化
Auto Delete: 当最后一个绑定到 Exchange上的队列删除后,自动删除该 Exchange
Internal: 当前 Exchange 是否用于 RabbitMQ 内部使用,默认为 False
Arguments: 扩展参数,用于扩展 AMQP 协议自定化使用
常用交换机类型
Direct Exchange
所有发送到 Direct Exchange 的消息被转发到 RouteKey 中指定的 Queue。此类型 Exchange 中生产者发送消息指定的 routingKey 与 消费者中 Exchange 和 Queue 绑定时指定的 routingKey 相同,否则发送失败。
注意:Direct 模式可以使用 RabbitMQ 自带的 Exchange(default Exchange),所以可以不需要将 Exchange 进行任何绑定操作,但是消息传递时,RouteKey 必须完全匹配才会被队列接收,否则该消息会被抛弃。
上图来源于某视频课程截图,如侵权,请联系立即删除!
DirectProducer.java
import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.ConnectionFactory;
public class DirectProducer {
public static void main(String[] args) throws Exception {
ConnectionFactory connectionFactory = new ConnectionFactory();
connectionFactory.setHost("192.168.0.125");
connectionFactory.setPort(5672);
connectionFactory.setVirtualHost("/");
// 获取连接
Connection connection = connectionFactory.newConnection();
// 创建信道
Channel channel = connection.createChannel();
// 通过信道发送信息
String exchangeName = "test.exchange.direct";
String routingKey = "key.direct";
for(int i = 0; i < 3; i++) {
String msg = "rabbitmq Producer: direct exchange test send message ";
// channel.basicPublish(exchange, routingKey, props, body);
channel.basicPublish(exchangeName, routingKey, null, msg.