Rabbitmq详解

1.mq是什么?

       MQ全称为Message Queue, 消息队列(MQ)是一种应用程序对应用程序的通信方法。应用程序通过读写出入队列的消息(针对应用程序的数据)来通信,而无需专用连接来链接它们。消息传递指的是程序之间通过在消息中发送数据进行通信,而不是通过直接调用彼此来通信,直接调用通常是用于诸如远程过程调用的技术。排队指的是应用程序通过 队列来通信。队列的使用除去了接收和发送应用程序同时执行的要求。

         此外除了Rabbitmq,其他的还有qpid、Activemq、Zeromq、Kafka等消息中间件技术。Rabbitmq是通过erlang语言进行开发的,是APMQ(高级消息队列协议)的标准实现。 

消息队列技术是分布式应用间交换信息的一种技术,消息队列可驻留在内存或者磁盘上,队列存储消息直到它们被应用程序读走,通过消息队列,应用程序可独立的执行---它们不需要知道彼此的位置。或者继续执行前不需要等待接收程序接收此消息。


   

2.mq做什么?

        首先了解一下mq的几个概念:

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

      


      这里简单举个栗子:   比如说在我们的程序中,有这么一个点赞的业务点,且这个业务触发的也非常频繁,如果说使用同步处理的话,那就会使服务器负担增加,而且服务请求效率慢,严重影响了用户的体验效果。所以这里我们就需要用到异步处理,将消息请求放在队列中,让客户端进行异步处理,实时的给予用户一个反馈,提升用户的体验,然后后台这边在进行数据修改和处理,达到一种异步的效果。

      再举一个更贴切的栗子:   比如说我们平时取快递,一个客户过去说:"我要取个快递",这时快递小哥就会把你的快递给你拿过来,你就成功的取到了快递。但是如果一群人过去取快递,快递小哥这时就忙不过来了,因为他要一个一个的去拿快递,很显然,客户就会一直在那里等啊等的,严重的影响了客户的体验。 这时快递小哥换了一个方法,他让客户说一下地址,然后让客户先回去,之后再把快递送过去,这样一来客户就避免了一直等待的过程,提高了客户的体验,快递小哥也轻松不少。这就是异步请求的作用。


3.mq怎么用?

       具体使用请查看官方文档:   点击打开链接

       另外也可参照:   https://www.cnblogs.com/enjoyall/p/7767462.html

                               https://www.cnblogs.com/SFLYQ/p/7358283.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值