Qianfeng

DON'T WORRY BE HAPPY
  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

rabbitmq概念总结

Posted on 2022-08-02 23:33  RonnieOS  阅读(19)  评论(0编辑  收藏  举报

rabbitmq是一种消息中间件,需要掌握的核心概念是publish, subscribe, broker, virtual host, exchange, queue, routing key.

publish: 生产者向broker发送消息
subscribe: 消费者从queue中取消息,一个queue可能对应多个exchange。

exchange在接收到消息时,会根据routing key将消息分发到若干queue。分发机制有四种:1. direct 2. fanout 3. topic 4. header

  1. direct
    绑定到当前exchange的queue的binding key必须严格相等于消息的routing key, 才会进行分发

  2. fanout
    广播。所有只要绑定到当前exchange的queue,都能收到消息

  3. topic
    正则匹配。queue绑定exchange时的binding key是一个字符串pattern,只有消息routing key匹配上了queue的binding key pattern, 就会进行分发

  4. header
    不依据routing key进行分发。queue在绑定exchange的时候,指定argument属性。发送message到exchange时,会指定headers,如果某个queue的argument里的所有属性全都被包含在了message的header里并且值相等,那么exchange就会将这条消息分发给他。