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的流量

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值