RabbitMQ 相关概念和方法详解(转)

RabbitMQ 相关概念和方法详解

名词解释

  • ConnectionFactory: 与 RabbitMQ 服务器连接的管理器。
  • Connection: 与 RabbitMQ 服务器的连接。
  • Channel: 与 Exchange 的连接。
  • Exchange: 接收生产者的消息,并根据消息的 RoutingKeyExchange 绑定的 BindingKey 分配消息。
  • Queue: 存储消费者的消息。
  • RoutingKey: 指定当前消息被谁接收。
  • BindingKey: 指定当前 Exchange 下,什么样的 RoutingKey 会被下派到当前绑定的 Queue 中。

exchange_declare 方法详解

def exchange_declare(self, callback=None, exchange=None, exchange_type='direct', passive=False, durable=False, auto_delete=False, internal=False, nowait=False, arguments=None):
  • callback 如果 nowait=TrueExchange.DeclareOk 时,调用这个回调方法。
  • exchange 交换器名称。
  • exchange_type 交换器类型,常见的如 fanout direct topic
  • passive 如果为 true , 则执行声明或者检查交换器是否存在。
  • durable 设置是否持久化。durable 设置为 true 表示持久化,反之非持久化。持久化可以将交换器存盘,在服务器重启的时候不会丢失消息。
  • auto_delete 设置是否自动删除。auto_delete 设置为 true 则表示自动删除。自动删除的前提是至少有一个队列或者交换器绑定,之后所有与这个交换器绑定的队列或者交换器都与此解绑。注意不能错误地把这个参数理解为:"当与此交换器连接的客户端都断开时,RabbitMQ 会自动删除本交换器"。
  • internal 设置是否是内置的。如果设置为 true,则表示是内置的交换器,客户端程序无法直接发送消息到这个交换器中,只能通过交换器路由到交换器这种方式。
  • nowait 如果设置为 false, 则不期望 RabbitMQ 服务器有一个 Exchange.DeclareOk 这样响应。
  • arguments 其他一些结构化参数。比如:alternate-exchange

exchange_bind 方法详解

def exchange_bind(self, callback=None, destination=None, source=None, routing_key='', nowait=False, arguments=None):
  • callback 如果 nowait=TrueExchange.DeclareOk 时,调用这个回调方法。
  • destinaction 一种交换器。
  • source 消息从 source 交换器转发到 destination 交换器,从某种程度上看 destination 交换器可以是一种队列。
  • routing_key 用来绑定队列和交换器的路由键。
  • nowait 如果设置为 false, 则不期望 RabbitMQ 服务器有一个 Exchange.DeclareOk 这样响应。
  • arguments 其他一些结构化参数。

queue_declare 方法详解

def queue_declare(self, queue='', passive=False, durable=False, exclusive=False, auto_delete=False, arguments=None):
  • queue 队列名称。
  • passive 如果为 true , 则执行声明或者检查队列是否存在。
  • durable 设置是否持久化。为 true 则设置队列为持久化。持久化的队列会存盘,在服务器重启的时候可以保证不丢失相关的信息。
  • exclusive 设置是否排他。为 true 则设置队列为排他的。如果一个队列被声明为排他队列,该队列对首次声明它的连接可见,并在连接断开时自动删除。这里需要注意三点:
    • 排他队列是基于连接(Connection)可见的,同一个连接的不同信道(Channel)是可以同时访问同一个连接创建的排他队列。
    • "首次" 是指如果一个连接已经声明了一个排他队列,其他连接是不允许建立同名的排他队列,这个与普通队列不同。
    • 即使该队列是持久化的,一旦连接关闭或者客户端退出,该队列都会被自动删除,这种队列适用于一个客户端同时发送和读取消息的应用场景。
  • auto_delete 设置是否自动删除。为 true 则设置队列为自动删除。自动删除的前提是:至少有一个消费者连接到这个队列,之后所有与这个队列连接的消费者都断开时,才会自动删除。不能把这个参数错误的理解为:"当连接到此队列的所有客户端断开时,这个队列自动删除",因为生产者客户端创建这个队列,或者没有消费者客户端与这个队列连接时,都不会自动删除这个队列。
  • arguments 设置队列的其他一些参数,如 x-message-ttl、x-expires、x-max-length

queue_bind 方法详解

def queue_bind(self, queue, exchange, routing_key=None, arguments=None):
  • queue 队列名称。
  • exchange 交换器的名称。
  • routing_key 用来绑定队列和交换器的路由键。
  • arguments 定义绑定的一些参数。

basic_publish 方法详解

def basic_publish(self, exchange, routing_key, body, properties=None, mandatory=False, immediate=False):
  • exchange 交换器的名称,指明消息需要发送到哪个交换器。如果设置为空字符串,则消息会被发生到 RabbitMQ 默认的交换器中。
  • routing_key 路由键,交换器根据路由键将消息存储到相应的队列之中。
  • properties 消息的基本属性集,其包含 14 个属性成员,分别有 contentTypedeliveryModeproiotity等。
  • body 消息体 payload,真正需要发送的消息。
  • mandatory 当参数设置为 true 时,交换器无法根据自身的类型和路由键找到一个符合条件的队列,那么 RabbitMQ 会调用 Basic.Return 命令消息返回给生产者。当参数设置为 false 时,出现上述情况,则消息直接丢失。
  • immediate 当参数设置为 true 时,如果交换器在将消息路由到队列时发现队列上并不存在任何消费者,那么这条消息将不会存入队列中。当与路由键匹配的所有队列都没有消费者时,该消息会通过 Basic.Return 返回至生产者。

basic_consume 方法详解

def basic_consume(self, consumer_callback, queue='', no_ack=False, exclusive=False, consumer_tag=None, arguments=None):
  • consumer_callback 设置消费者的回调函数。用来处理 RabbitMQ 推送过来的消息,比如:DefaultConsumer,使用时需要客户端重写其中的方法。
  • queue 队列的名称。
  • no_ack 设置是否自动确认。建议设置成 false,即不自动确认。
  • exclusive 设置是否排他。
  • consumer_tag 消费者标签,用来区分多个消费者。
  • arguments 设置消费者的其他参数。

exchange_type 模式

fanout 模式

  • 任何发送到 fanout exchange 的消息都会被转发到与 exchange 绑定的所有的 queue 上。
  • 不需要指定 routing_key, 即使指定了也是无效的。
  • 需要提前将 exchangequeue 进行绑定, 一个 exchange 可以绑定到多个 queue, 一个 queue 也可以同多个 exchange 进行绑定。
  • 接收到消息的 exchange 没有与任何 queue 绑定, 则消息就会被抛弃。

direct 模式

  • 发送到 direct exchange 的消息都会被转发到 routing_key 中指定的 queue
  • 不需要将 exchange 进行任何绑定操作。当然也可以进行绑定操作,可以将不同的 routing key 与不同的 queue 进行绑定,不同的 queue 与不同 exchange 进行绑定。
  • 消息需要传递一个 routing_key
  • 如果消息中不存在 routing_key 中绑定的队列名,则该消息就会被抛弃。
  • 如果一个 exchange 声明为 direct,并且绑定中指定了 routing_key,那么发生消息时。需要同时指明该 exchangerouting_key

topic 模式

  • 这种模式比较复杂,简单来说,就是每个队列都有其关心的主题,所有的消息都带有一个 routing_keyexchange 会将消息转发到所有关注主题能与 routing_key 模糊匹配的队列。
  • 需要 routing_key 要提前绑定 exchangequeue
  • 在进行绑定的时候,要提供一个该队列关心的主题,如:"#.log.#" 表示该队列关心所涉及 log 的消息(一个 routing_key 为 "MQ.log.error" 的消息会被转发到该队列)。
  • "#" 表示 0 个或若干个关键字,"" 表示一个关键字。如 "log." 能与 "log.warn.timeout" 匹配,但是 "log.#" 能与上述匹配。
  • 如果 exchange 没有发现能够与 routing_key 匹配的 Queue,则会抛弃此消息。

转发

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,384评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,845评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,148评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,640评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,731评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,712评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,703评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,473评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,915评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,227评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,384评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,063评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,706评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,302评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,531评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,321评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,248评论 2 352

推荐阅读更多精彩内容