分享

rabbitmq Exchange Queue RoutingKey关系说明

 用勿龍潛 2014-06-08

String queue = channel.queueDeclare("test.queue").getQueue();

Rabbitmq Server 会有以下操作:

  • 定义了一个queue,名称为test.queue

  • queue的名称(test.queue)作为routingKey,将当前这个queue binding到一个默认的exchange(名称为空,服务器自动创建的)上


如果我们 binding的话

channel.queueBind("test.queue", "test.exchange", "test.routingkey");

上边和默认的Exchange进行的binding还是会存在的

  channel.basicPublish("", QUEUE_NAME, null, message.getBytes());
//  RabbitMQ默认有一个exchange,叫default exchange,它用一个空字符串表示,它是direct exchange类型
//  ,任何发往这个exchange的消息都会被路由到routing key的名字对应的队列上,如果没有对应的队列,则消息会被丢弃
//  。这就是为什么代码中channel执行basicPulish方法时,第二个参数本应该为routing key,却被写上了QUEUE_NAME。


经过同事lucas多次测试发现,以前认为RoutingKey是唯一的或由Exchange和RoutingKey决定一条唯一的由Exchange到Queue的线路是不正确的
测试结果如下:

Exchange Name

Queue Name

Routing Key

 

test.queue     

test.queue

 

test.queue2    

test.queue2

test.exchange  

test.queue     

test.routingkey

test.exchange  

test.queue2    

test.routingkey

test.exchange  

test.queue     

test.routingkey2

test.exchange1

test.queue     

test.routingkey

由结果可以看出,由ExchangeQueueRoutingKey三个才能决定一个从Exchange到Queue的唯一的线路。

画张图,不是很准确

rabbitmq 学习-8- Exchange Queue RoutingKey关系说明 - micro sun - 学无止境

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多