RabbitMQ 第二章

消息只能存储在队列中,多个消费者可订阅同一个队列,此时队列中消息会被平均分摊。 n consumer->1 queue

生产者将消息投递到交换机上,再由交换机将消息路由到一个或多个队列中

RoutingKey  与  BindingKey 与 交换机类型 联合使用生效

Binding: 将交换机与队列相关联起来   绑定时需要指定BindingKey   MQServer即可知道应该将消息路由到哪个队列中

BindingKey与RoutingKey相匹配时,消息被路由到对应的队列中。

fanout类型的交换器无视bindingKey。

使用direct类型的交换器,将交换器与队列进行绑定使用RoutingKey。

在direct交换器下   RoutingKey与BindingKey需要完全匹配才能生效。

在topic交换器下  RoutingKey与BindingKey之间做模糊匹配,并不是完全相同才可以。

交换器类型:

fanout:

将消息发送到所有与该交换器绑定的队列中。

direct:

把消息路由到 BindingKey与 RoutingKey完全匹配的队列中

topic:

把消息路由到BindingKey与RoutingKey模糊匹配的队列中

规则:

RoutingKey 与 BindingKey均为为一个点号"."分隔的字符串  如com.rabbitmq.client

BindingKey 中可以存在两种特殊字符串   "*"与"#"将其用于模糊匹配中

其中  *用于匹配一个单词   #可匹配(0-n)个单词

headers:根据发送消息内容的headers属性进行匹配   性能差  不建议使用。

客户端与 服务器建立链接  也就是  TCP连接   Connection

建立好 TCP连接后 客户端创建AMQP信道   channel   每个信道被指派唯一id

其中Connection  的TCP链接是多个客户端复用的   因为服务端建立和销毁TCP链接消耗较大

类似于NIO多路复用

而channel则是客户端私有的

当单个channel流量不是很大时  公用一个connection 能取得较好的效果

但是当单个channel流量很大时   共用connection 会成为性能瓶颈

此时需要线程池来创建多个connection来均摊channel的流量

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值