1.mq是什么?
MQ全称为Message Queue, 消息队列(MQ)是一种应用程序对应用程序的通信方法。应用程序通过读写出入队列的消息(针对应用程序的数据)来通信,而无需专用连接来链接它们。消息传递指的是程序之间通过在消息中发送数据进行通信,而不是通过直接调用彼此来通信,直接调用通常是用于诸如远程过程调用的技术。排队指的是应用程序通过 队列来通信。队列的使用除去了接收和发送应用程序同时执行的要求。
此外除了Rabbitmq,其他的还有qpid、Activemq、Zeromq、Kafka等消息中间件技术。Rabbitmq是通过erlang语言进行开发的,是APMQ(高级消息队列协议)的标准实现。
消息队列技术是分布式应用间交换信息的一种技术,消息队列可驻留在内存或者磁盘上,队列存储消息直到它们被应用程序读走,通过消息队列,应用程序可独立的执行---它们不需要知道彼此的位置。或者继续执行前不需要等待接收程序接收此消息。
2.mq做什么?
首先了解一下mq的几个概念:
- Broker:简单来说就是消息队列服务器实体。
- Exchange:消息交换机,它指定消息按什么规则,路由到哪个队列。
- Queue:消息队列载体,每个消息都会被投入到一个或多个队列。
- Binding:绑定,它的作用就是把exchange和queue按照路由规则绑定起来。
- Routing Key:路由关键字,exchange根据这个关键字进行消息投递。
- vhost:虚拟主机,一个broker里可以开设多个vhost,用作不同用户的权限分离。
- producer:消息生产者,就是投递消息的程序。
- consumer:消息消费者,就是接受消息的程序。
- channel:消息通道,在客户端的每个连接里,可建立多个channel,每个channel代表一个会话任务。 mq流程图
这里简单举个栗子: 比如说在我们的程序中,有这么一个点赞的业务点,且这个业务触发的也非常频繁,如果说使用同步处理的话,那就会使服务器负担增加,而且服务请求效率慢,严重影响了用户的体验效果。所以这里我们就需要用到异步处理,将消息请求放在队列中,让客户端进行异步处理,实时的给予用户一个反馈,提升用户的体验,然后后台这边在进行数据修改和处理,达到一种异步的效果。
再举一个更贴切的栗子: 比如说我们平时取快递,一个客户过去说:"我要取个快递",这时快递小哥就会把你的快递给你拿过来,你就成功的取到了快递。但是如果一群人过去取快递,快递小哥这时就忙不过来了,因为他要一个一个的去拿快递,很显然,客户就会一直在那里等啊等的,严重的影响了客户的体验。 这时快递小哥换了一个方法,他让客户说一下地址,然后让客户先回去,之后再把快递送过去,这样一来客户就避免了一直等待的过程,提高了客户的体验,快递小哥也轻松不少。这就是异步请求的作用。
3.mq怎么用?
具体使用请查看官方文档: 点击打开链接