RabbitMQの3種類の交換モード(ファンアウト、直接、トピック)の性能比較

RabbitMQの3種類の交換モード(ファンアウト、直接、トピック)の性能比較

一.Direct交換

0ec0f465-49c6-361c-ae2b-dd951a6ed1a9

任意のメッセージを送信するための直接交換は、キューを指定RouteKeyに転送されます。

1.一般的な使用のRabbitMQは、Exchangeが来る:「」(名前は空の文字列所で、以下、デフォルトのExchangeと呼びます)。

このモードでは、すべてのExchange(バインド)2.操作を必要とせず結合

「RouteKey」3.メッセージングが必要です、それは単に送信するキューの名前として理解することができます。

キュー名が指定されたバーチャルホストRouteKey存在しない場合は4は、そのメッセージは破棄されます。

 

二.Fanout交換 

0bbdcd3d-9fc6-3107-b7e0-db67c174d46a

 

ファンアウトExchangeに送信されたメッセージは、のすべてのExchangeキューバインド(バインド)に転送されます。

1.パターンは、ルーティングテーブルとして理解することができます

2.このモードはRouteKeyを必要としません。

3.このモデルは、Exchangeキューバインドと前進を必要とし、あなたが複数のExchangeキューをバインドすることができ、キューは、複数のExchangeと結合することができます。

受信したメッセージとExchangeが任意のキューを結合しない場合4.、そのメッセージは破棄されます。

 

三.Topic交換

11171ab4-af07-3ff6-bdf6-d1febda679c3

 

トピックExchangeに送信されたメッセージは、すべてのRouteKey指定された関係のトピックのキューに転送されます

1.このモデルは、簡単な言葉で、より複雑である各キューは、「タイトル」(RouteKey)と、すべてのメッセージが提示されている懸念し、独自のテーマを持っていることである、ExchangeはぼかしとRouteKeyことができ、すべての関係のトピックにメッセージを転送しますマッチングキュー。

2.このモデルは、おそらく取引所キューの前進をバインドするために、RouteKeyが必要です。

3.在进行绑定时,要提供一个该队列关心的主题,如“#.log.#”表示该队列关心所有涉及log的消息(一个RouteKey为”MQ.log.error”的消息会被转发到该队列)。

4.“#”表示0个或若干个关键字,“*”表示一个关键字。如“log.*”能与“log.warn”匹配,无法与“log.warn.timeout”匹配;但是“log.#”能与上述两者匹配。

5.同样,如果Exchange没有发现能够与RouteKey匹配的Queue,则会抛弃此消息。

 http://hwcrazy.com/2a31095868c811e3ad76000d601c5586/group/free_open_source_project/

一.Direct Exchange

0ec0f465-49c6-361c-ae2b-dd951a6ed1a9

任何发送到Direct Exchange的消息都会被转发到RouteKey中指定的Queue。

1.一般情况可以使用rabbitMQ自带的Exchange:”"(该Exchange的名字为空字符串,下文称其为default Exchange)。

2.这种模式下不需要将Exchange进行任何绑定(binding)操作

3.消息传递时需要一个“RouteKey”,可以简单的理解为要发送到的队列名字。

4.如果vhost中不存在RouteKey中指定的队列名,则该消息会被抛弃。

 

二.Fanout Exchange 

0bbdcd3d-9fc6-3107-b7e0-db67c174d46a

 

任何发送到Fanout Exchange的消息都会被转发到与该Exchange绑定(Binding)的所有Queue上。

1.可以理解为路由表的模式

2.这种模式不需要RouteKey

3.这种模式需要提前将Exchange与Queue进行绑定,一个Exchange可以绑定多个Queue,一个Queue可以同多个Exchange进行绑定。

4.如果接受到消息的Exchange没有与任何Queue绑定,则消息会被抛弃。

 

三.Topic Exchange

11171ab4-af07-3ff6-bdf6-d1febda679c3

 

トピックExchangeに送信されたメッセージは、すべてのRouteKey指定された関係のトピックのキューに転送されます

1.このモデルは、簡単な言葉で、より複雑である各キューは、「タイトル」(RouteKey)と、すべてのメッセージが提示されている懸念し、独自のテーマを持っていることである、ExchangeはぼかしとRouteKeyことができ、すべての関係のトピックにメッセージを転送しますマッチングキュー。

2.このモデルは、おそらく取引所キューの前進をバインドするために、RouteKeyが必要です。

3.例えば、「#.logという。#」として、結合作りキューへの関心の話題を提供するために、「MQ.log.error」のメッセージとして(RouteKeyログに関わるすべてのメッセージのキューのケアが転送されることを示しますキューに)。

4.「#」は0またはいくつかのキーワードを表し、「*」のキーワードを示します。しかし、両方と一致する;「ログイン*」としては、 『log.warn.timeout』と一致しないことができ、 『log.warn』を一致させることができる「ログ#を。」。

ExchangeがRouteKeyキューと一致することが可能であることが見出されていない場合5.同様に、このメッセージは破棄されます。

 http://hwcrazy.com/2a31095868c811e3ad76000d601c5586/group/free_open_source_project/

おすすめ

転載: www.cnblogs.com/tellerfuliye/p/12034314.html
おすすめ