rabbitmq

概述
本文介绍RabbitMQ中交换机类型和属性,主要内容如下:

交换机的作用
交换机的类型:Direct exchange(直连交换机)、Fanout exchange(扇型交换机)、Topic exchange(主题交换机)、Headers exchange(头交换机)、默认存在的交换机、Dead Letter Exchange(死信交换机)
交换机的属性
交换机的作用
之前的例子中,我们是通过队列发送和接收消息的,但是实际上里面还有一个重要的组合交换机,完整消息流程如下:


在RabbitMQ中,生产者不是直接将消息发送给消费者,生成者根本不知道这个消息要传递给哪些队列。实际上,生产者只是将消息发送到交换机。交换机收到消息到,根据交换机的类型和配置来处理消息,有如下几种情况:

将消息传送到特定的队列
有可能发送到多个队列中
也有可能丢弃消息
RabbitMQ各个组件的功能重新归纳一下如下:

生产者:发送消息
交换机:将收到的消息根据路由规则路由到特定队列
队列:用于存储消息
消费者:收到消息并消费
交换机的类型:
交换机主要包括如下4种类型:

Direct exchange(直连交换机)
Fanout exchange(扇型交换机)
Topic exchange(主题交换机)
Headers exchange(头交换机)
另外RabbitMQ默认定义一些交换机:

默认交换机
amq.* exchanges
还有一类特殊的交换机:Dead Letter Exchange(死信交换机)

Direct exchange(直连交换机)


直连型交换机(direct exchange)是根据消息携带的路由键(routing key)将消息投递给对应队列的,步骤如下:

将一个队列绑定到某个交换机上,同时赋予该绑定一个路由键(routing key)
当一个携带着路由值为R的消息被发送给直连交换机时,交换机会把它路由给绑定值同样为R的队列。
Fanout exchange(扇型交换机)


扇型交换机(funout exchange)将消息路由给绑定到它身上的所有队列。不同于直连交换机,路由键在此类型上不启任务作用。如果N个队列绑定到某个扇型交换机上,当有消息发送给此扇型交换机时,交换机会将消息的发送给这所有的N个队列

Topic exchange(主题交换机)


主题交换机(topic exchanges)中,队列通过路由键绑定到交换机上,然后,交换机根据消息里的路由值,将消息路由给一个或多个绑定队列。

扇型交换机和主题交换机异同:

对于扇型交换机路由键是没有意义的,只要有消息,它都发送到它绑定的所有队列上
对于主题交换机,路由规则由路由键决定,只有满足路由键的规则,消息才可以路由到对应的队列上
Headers exchange(头交换机)
类似主题交换机,但是头交换机使用多个消息属性来代替路由键建立路由规则。通过判断消息头的值能否与指定的绑定相匹配来确立路由规则。
此交换机有个重要参数:”x-match”

当”x-match”为“any”时,消息头的任意一个值被匹配就可以满足条件
当”x-match”设置为“all”的时候,就需要消息头的所有值都匹配成功
RabbitMQ默认定义一些交换机
在RabbitMQ默认定义一些交换机,主要如下:

默认交换机
默认交换机(default exchange)实际上是一个由RabbitMQ预先声明好的名字为空字符串的直连交换机(direct exchange)。它有一个特殊的属性使得它对于简单应用特别有用处:那就是每个新建队列(queue)都会自动绑定到默认交换机上,绑定的路由键(routing key)名称与队列名称相同。

如:当你声明了一个名为”hello”的队列,RabbitMQ会自动将其绑定到默认交换机上,绑定(binding)的路由键名称也是为”hello”。因此,当携带着名为”hello”的路由键的消息被发送到默认交换机的时候,此消息会被默认交换机路由至名为”hello”的队列中。即默认交换机看起来貌似能够直接将消息投递给队列,如同我们之前文章里看到一例子。

类似amq.*的名称的交换机

这些是RabbitMQ默认创建的交换机。这些队列名称被预留做RabbitMQ内部使用,不能被应用使用,否则抛出403 (ACCESS_REFUSED)错误

Dead Letter Exchange(死信交换机)
在默认情况,如果消息在投递到交换机时,交换机发现此消息没有匹配的队列,则这个消息将被悄悄丢弃。为了解决这个问题,RabbitMQ中有一种交换机叫死信交换机。当消费者不能处理接收到的消息时,将这个消息重新发布到另外一个队列中,等待重试或者人工干预。这个过程中的exchange和queue就是所谓的”Dead Letter Exchange 和 Queue”

交换机的属性
除交换机类型外,在声明交换机时还可以附带许多其他的属性,其中最重要的几个分别是:

Name:交换机名称
Durability:是否持久化。如果持久性,则RabbitMQ重启后,交换机还存在
Auto-delete:当所有与之绑定的消息队列都完成了对此交换机的使用后,删掉它
Arguments:扩展参数

 

exchange_declare参数说明:

exchange:交换机名称

type:交换机类型,常见的如fanout、direct、topic

durable:设置是否持久化。durable设置true表示持久化,反之是持久化。持久化可以将将换机存盘,在服务器重启时不会丢失相关信息

autoDelete:设置是否自动删除。autoDelete设置为true则表示自动删除。自动删除的前提是至少有一个队列或者交换机与这个交换器绑定的队列或者交换器都与之解绑

internal:设置是否内置的。如果设置为true,则表示是内置的交换器,客户端程序无法直接发送消息到这个交换器中,只能通过交换器路由到交换器这种方式

argument:其他一些结构化参数,比如alternate-exchange

 

queue_declare 参数详解

  • queue_declare ()不带参数方法默认创建一个由RabbitMq命名的(amq.gen-LHQZz...)
    名称,这种队列也称之为匿名队列,排他 的,自动删除的,非持久化的队列
  • queue:队列名称
  • passive:如果用户仅仅想查询某一个队列是否已存在,如果不存在,不想建立该队列,仍然可以调用queue.declare,只不过需要将参数passive设为true,传给queue.declare,如果该队列已存在,则会返回true;如果不存在,则会返回Error,但是不会创建新的队列。
  • durable: 是不持久化, true ,表示持久化,会存盘,服务器重启仍然存在,false,非持久化
  • exclusive : 是否排他的,true,排他。如果一个队列声明为排他队列,该队列公对首次声明它的连接可见,并在连接断开时自动删除,
  • auto_delete :是否自动删除,true,自动删除,自动删除的前提:至少有一个消息者连接到这个队列,之后所有与这个队列连接的消息都断开时,才会自动删除,备注:生产者客户端创建这个队列,或者没有消息者客户端连接这个队列时,不会自动删除这个队列
  • arguments:其它一些参数。如:x-message-ttl,之类

 

默认的exchange:如果用空字符串去声明一个exchange,那么系统就会使用””AMQP default”这个exchange,我们创建一个queue时,默认的都会有一个和新建queue同名的routingKey绑定到这个默认的exchange上去

 

 

$channel->basic_consume("TestQueue", "", false, false, false, false, $callback);

顺序参数名默认值作用
1queue 消息要取得消息的队列名
2consumer_tag 消费者标签
3no_localfalse这个功能属于AMQP的标准,但是rabbitMQ并没有做实现.
4no_ackfalse收到消息后,是否不需要回复确认即被认为被消费
5exclusivefalse排他消费者,即这个队列只能由一个消费者消费.适用于任务不允许进行并发处理的情况下.比如系统对接
6nowaitfalse不返回执行结果,但是如果排他开启的话,则必须需要等待结果的,如果两个一起开就会报错
7callbacknull回调函数
8ticketnull 
9argumentsnull 

 

basic_qos($prefetch_size, $prefetch_count, $a_global)

$prefetch_count:一次接受几个

$a_global:设置为Null,是指应用到本消费端,不应用到channel

 

DIRECT实例

TOPIC实例

Fanout Exchange

rabbitmq限流操作

应设置自动回复ack为false,在没有ack确认之前,不会继续接收消息

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值