Springboot集成RabbitMq Exchange交换机

   日期:2020-08-20     浏览:105    评论:0    
核心提示:Exchange交换机和FanoutExchange交换机一样都是无视key的。他会根据headers参数来匹配,然后发送消息到相应的消息队列。匹配规则有两个Where Any --头部信息至少有一个匹配Where All --头部信息必须完全匹配下面我们来创建交换机和队列,以及绑定。@Componentpublic class HeaderExchange { @Bean public Queue queue1(){ return new Queu

Exchange交换机和FanoutExchange交换机一样都是无视key的。
他会根据headers参数来匹配,然后发送消息到相应的消息队列。
匹配规则有两个

  • Where Any --头部信息至少有一个匹配
  • Where All --头部信息必须完全匹配
    下面我们来创建交换机和队列,以及绑定。
@Component
public class HeaderExchange {
    @Bean
    public Queue queue1(){
        return new Queue("testHeaderQueue");
    }
    @Bean
    public HeadersExchange createExchange(){
        return new HeadersExchange("testHeaderExchange");
    }
    @Bean
    public Binding bind1(){
        HashMap<String, Object> header = new HashMap<>();
        header.put("queue", "queue1");
        header.put("bindType", "whereAll");
        return BindingBuilder.bind(queue1()).to(createExchange()).whereAny(header).match();
    }
}

然后发送消息

    @RequestMapping("send")
    public String testHeaderExchange(String param){
        MessageProperties messageProperties = new MessageProperties();
        messageProperties.setContentType("text/plain");
        messageProperties.setContentEncoding("utf-8");
        messageProperties.setHeader("queue","queue1");
        Message message = new Message(param.getBytes(), messageProperties);
        rabbitTemplate.convertAndSend("testHeaderExchange",null,message);
        return "发送成功";
    }

再然后就是消费端的代码

@Component
public class TestHeader {
    @RabbitListener(queues = "testHeaderQueue")
    public void rest(String mes, Message message, Channel channel){
        Map<String, Object> headers = message.getMessageProperties().getHeaders();
        for (Map.Entry<String, Object> stringObjectEntry : headers.entrySet()) {
            System.out.println("key---->"+stringObjectEntry.getKey());
            System.out.println("value---->"+stringObjectEntry.getValue());

        }
        System.out.println("接收到的消息"+mes);
        try {
            channel.basicAck(message.getMessageProperties().getDeliveryTag(),false);
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}


我们这边成功接收。
本文参照 此文章

 
打赏
 本文转载自:网络 
所有权利归属于原作者,如文章来源标示错误或侵犯了您的权利请联系微信13520258486
更多>最近资讯中心
更多>最新资讯中心
0相关评论

推荐图文
推荐资讯中心
点击排行
最新信息
新手指南
采购商服务
供应商服务
交易安全
关注我们
手机网站:
新浪微博:
微信关注:

13520258486

周一至周五 9:00-18:00
(其他时间联系在线客服)

24小时在线客服