RabbitMQ二三事

栏目: Redis · 发布时间: 6年前

内容简介:RabbitMQ简单理解就是一个队列服务,我们的生产者不断地往它投递消息,而消费者不断地从它那里获取消息。但相较于利用RabbitMQ中

RabbitMQ概览

RabbitMQ 是一个高性能的分布式消息中间件。它由 Erlang 编写,这种语言天生支持分布式,而且性能极高(但是比较难上手)。

通信概念

RabbitMQ简单理解就是一个队列服务,我们的生产者不断地往它投递消息,而消费者不断地从它那里获取消息。但相较于利用 redis 的List这类简单队列,RabbitMQ的消息投递更灵活一点。首先需要知道一些RabbitMQ中的通信概念:

  • Exchange(交换器)
  • Queue(队列)
  • Producer(生产者)
  • Consumer(消费者)

RabbitMQ中 Exchange 类似于一个路由器,我们的 Consumer 并不会把消息直接投递给队列,而是投递给 ExchangeExchange 根据我们投递时的路由键(routing key)再发送到特定的队列。这样的设计让消息可以灵活选路,发送到某一类的队列中,形成一对多的关系,而不仅仅是一对一。

Exchange

所以说RabbitMQ中的 Exchange 很方便,很强大,它有这样几种类型:

  • direct
  • fanout
  • topic
  • headers(几乎用不到)

direct 交换器很简单,有时候我们仅仅需要一个很简单的队列(消息投递到其中,然后不断消费它),这时候我们就可以用 direct 交换器,它的规则是:如果路由键匹配,消息就会被投递到对应的队列。

RabbitMQ二三事

fanout 交换器忽略路由键,把消息 同时 发到一批队列。

RabbitMQ二三事

topic 则就是根据不同路由键,把消息发送到某一类队列中。

RabbitMQ二三事


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

C语言接口与实现

C语言接口与实现

(美)David R. Hanson / 人民邮电出版社 / 2010-8 / 79.00元

可重用的软件模块是构建大规模可靠应用程序的基石,创建可重用的软件模块是每个程序员和项目经理必须掌握的技能。C语言对创建可重用的API提供的语言和功能支持非常少,虽然C程序员写应用时都会用到API和库,但却很少有人去创建和发布新的能广泛应用的API。本书介绍用一种基于接口的设计方法创建可重用的API,这一方法将接口与实现分离开来,且与语言无关。书中详细描述了24个接口及其实现,便于读者深入了解此方法......一起来看看 《C语言接口与实现》 这本书的介绍吧!

URL 编码/解码
URL 编码/解码

URL 编码/解码

SHA 加密
SHA 加密

SHA 加密工具

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具