饰品销售网站功能建设wordpress文章页面500
1、简介
MQ,中文是消息中间件(队列)(MessageQueue),字面来看就是存放消息的队列。也就是事件驱动架构中的Broker。
 简单来说,消息中间件就是指保存数据的一个容器(服务器),可以用于两个系统之间的数据传递。
几种常见MQ的对比:
| RabbitMQ | ActiveMQ | RocketMQ | Kafka | |
|---|---|---|---|---|
| 公司/社区 | Rabbit | Apache | 阿里 | Apache | 
| 开发语言 | Erlang | Java | Java | Scala&Java | 
| 协议支持 | AMQP,XMPP,SMTP,STOMP | OpenWire,STOMP,REST,XMPP,AMQP | 自定义协议 | 自定义协议 | 
| 可用性 | 高 | 一般 | 高 | 高 | 
| 单机吞吐量 | 一般 | 差 | 高 | 非常高 | 
| 消息延迟 | 微秒级 | 毫秒级 | 毫秒级 | 毫秒以内 | 
| 消息可靠性 | 高 | 一般 | 高 | 一般 | 
追求可用性:Kafka、 RocketMQ 、RabbitMQ
追求可靠性:RabbitMQ、RocketMQ
追求吞吐能力:RocketMQ、Kafka
追求消息低延迟:RabbitMQ、Kafka
=======================================================================
RabbitMQ是一个广泛使用的消息服务器,采用Erlang语言编写,是一种开源的实现 AMQP(高级消息队列协议)的消息中间件;
消息中间件一般有三个主要角色:生产者、消费者、消息代理(消息队列、消息服务器);
生产者发送消息到消息服务器,然后消费者从消息代理(消息队列)中获取数据并进行处理;
MQ的基本结构:
 
RabbitMQ中的一些角色:
- publisher:生产者
 - consumer:消费者
 - exchange个:交换机,负责消息路由
 - queue:队列,存储消息
 - virtualHost:虚拟主机,隔离不同租户的exchange、queue、消息的隔离
 
基本消息队列的消息发送流程:
-  
建立connection
 -  
创建channel
 -  
利用channel声明队列
 -  
利用channel向队列发送消息
 
基本消息队列的消息接收流程:
-  
建立connection
 -  
创建channel
 -  
利用channel声明队列
 -  
定义consumer的消费行为handleDelivery()
 -  
利用channel将消费者与队列绑定
 
2、RabbitMQ基本
RabbitMQ
3、SpringAMQP
SpringAMQP是基于RabbitMQ封装的一套模板,并且还利用SpringBoot对其实现了自动装配,使用起来非常方便。
SpringAMQP提供了三个功能:
- 自动声明队列、交换机及其绑定关系
 - 基于注解的监听器模式,异步接收消息
 - 封装了RabbitTemplate工具,用于发送消息
 
3.1.Basic Queue 简单队列模型
在父工程mq-demo中引入依赖
<!--AMQP依赖,包含RabbitMQ-->
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-amqp</artifactId>
</dependency>
 
3.1.1.消息发送
首先配置MQ地址,在publisher服务的application.yml中添加配置:
spring:rabbitmq:host: 192.168.150.101 # 主机名port: 5672 # 端口virtual-host: / # 虚拟主机username: itcast # 用户名password: 123321 # 密码
 
然后在publisher服务中编写测试类SpringAmqpTest,并利用RabbitTemplate实现消息发送:
package cn.itcast.mq.spring;import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;@RunWith(SpringRunner.class)
@SpringBootTest
public class SpringAmqpTest {@Autowiredprivate RabbitTemplate rabbitTemplate;@Testpublic void testSimpleQueue() {// 队列名称String queueName = "simple.queue";// 消息String message = "hello, spring amqp!";// 发送消息rabbitTemplate.convertAndSend(queueName, message);}
}
 
3.1.2.消息接收
首先配置MQ地址,在consumer服务的application.yml中添加配置:
spring:rabbitmq:host: 192.168.150.101 # 主机名port: 5672 # 端口virtual-host: / # 虚拟主机username: itcast # 用户名password: 123321 # 密码
 
然后
