RabbitMQ基本概念&&实战

MQ

MQ(message quene):翻译为消息队列,通过典型的生产者和消费者模式,生产者不断向消息队列中生产消息,消费者不断从队列中获取消息。因为消息的生产和消费都是异步的,而且只关心消息的发送和接收,没有业务逻辑的侵入,轻松实现系统之间的解耦

RabbitMQ

RabbitMQ是使用Erlang语言开发的开源消息队列系统,基于AMQP协议来实现。AMQP的主要特征是面向消息、队列、路由(点对点和发布/订阅)、可靠、安全。AMQP协议更多用在企业系统内对数据的一致性、稳定性和可靠性要求很高的场景,对性能和吞吐量的要求在其次(Kafka高性能,适用大数据)

——windows下载安装

1. 重要概念

  • Exchange:消息交换机,它指定消息按什么规则,路由到哪个队列。
  • Queue:消息队列载体,每个消息都会被投入到一个或多个队列。
  • Binding:绑定, 它的作用就是把exchange和queue按照路由规则绑定起来。
  • Routing Key:路由关键字, exchange根据这个关键字进行消息投递。
  • vhost:虚拟主机, 一个broker里可以开设多个vhost, 用作不同用户的权限分离。
  • producer:消息生产者,就是投递消息的程序。
  • consumer:消息消费者, 就是接受消息的程序。
  • channel:消息通道,在客户端的每个连接里,可建立多个channel,
    每个channel代表一个会话任务。

2. 结构图

在这里插入图片描述

3. 使用过程

  1. 客户端连接到消息队列服务器, 打开一个channel。
  2. 客户端声明一个exchange, 并设置相关属性。
  3. 客户端声明一个queue, 并设置相关属性。
  4. 客户端使用routing key, 在exchange和queue之间建立好绑定关系。
  5. 客户端投递消息到exchange。
    exchange接收到消息后, 就根据消息的key和已经设置的binding, 进行消息路由,将消息投递到一个或多个队列里。

交换机的创建取决于消费者是否消费

4. 消息可靠性

  • Message acknowledgment:消息回执
    应答机制下:收到回执才删除消息;未收到回执而连接断开,消息会转给其他消费者。
    应答机制下:忘记回执会导致消息堆积,业务重复处理
    采用非应答机制可以提升队列处理效率
  • Message durability:消息持久化
    可以避免绝大部分的消息丢失,如服务重启。 采用非持久化机制可以提升队列处理效率
    • (1) exchange持久化,在声明时指定durable=>1
    • (2) queue持久化,在声明时指定durable=>1
    • (3) 消息持久化,在投递时指定deivery_mode=>2(1是非持久化)
  • Prefetch count:每次发送给消费者消息数量, 默认1, 实践采用2

5. 交换机类型

Direct(直连):把消息路由到那些BindingKey和RoutingKey完全匹配的队列中

  • 适用场景:有优先级的任务,根据任务的优先级把消息发送到对应的队列,这样可以指派更多的资源去处理高优先级的队列

Fanout(扇形):把所有发送到该交换器的消息路由到所有与该交换器绑定的队列中

在这里插入图片描述
Topic(主题)
在这里插入图片描述
Headers(首部):不依赖路由键的匹配规则来路由消息,而是根据发送的消息内容中的headers属性进行匹配(基本不用)
在这里插入图片描述

6. 消息队列比较

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序少年不秃头

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值