一、概述
前面三篇文章讲述了RabbitMQ 常用的三种Exchange类型,这篇文章学习一下第四种不常用的Exchange类型:Headers这种类型与topic类型类似,只不过不是匹配routingKeys,是匹配AMQP协议中的Header,Header是一个HashTable类型的键值对,而routingKey是String类型的字符串。功能与Topic相同,消息发送者绑定消息的键值对,匹配交换机与队列之间绑定的键值对,匹配规则“x-match”有两种,一种是“any”,只要一组键值对匹配成功即可发送消息到该队列,另一种是“all”,即需要所有键值对都匹配才可以发送消息。
大概的场景应用示意图如下,详细说明见示例代码:
二、源代码
我们先测试any类型的headers,先写生产者代码,相关说明已在注释中标明
package com.cn.chenxyt.mq;
import java.io.IOException;
import java.util.Hashtable;
import java.util.Map;
import com.rabbitmq.client.AMQP.BasicProperties;
import com.rabbitmq.client.AMQP.BasicProperties.Builder;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.ConnectionFactory;
import com.rabbitmq.client.Channel;
public class MqProducer {
public final static String EXCHANGE_NAME="EX_HEADER";
public static void main(String[] args) throws IOException, InterruptedException {
//创建连接工厂
ConnectionFactory factory = new ConnectionFactory();
//设置主机、用户名、密码和客户端端口号
factory.setHost("localhost");
factory.setUsername("guest");
factory.setPassword("guest");
factory.setPort(5672);
//创建一个新的连接 即TCP连接
Connection connection = factory.newConnection();
//创建一个通道
Channel channel = connection.createChannel();
//创建一个交换机
channel.exchangeDeclare(EXCHANGE_NAME,"headers");
//定义发送消息的要绑定的键值对
Map<String,Object> headers = new Hashtable<String, Object>();
headers.put("aaa", "111");
headers.put("bbb", "222");
Builder properties = new BasicProperties.Builder();
properties.headers(headers);
for(int i = 0;i<500;i++){
String message = "hello" + (i);
//发送消息 绑定header键值对
channel.basicPublish(EXCHANGE_NAME,"",properties.build(),message.getBytes());
System.out.println("发送消息:" + message);
Thread.sleep(2000);
}
}