- 异步调用的缺点:
- 依赖于Broker的可靠性、安全性、吞吐能力
- 架构复杂了,业务没有明显的流程线,不好追踪管理
什么是MQ
MQ (MessageQueue),中文是消息队列,字面来看就是存放消息的队列。也就是事件驱动架构中的Broker。
下图是常见MQ组件的对比。
RabbitMQ安装
这里使用的是docker镜像安装的方式。
- 首先把RabbitMQ镜像上传到虚拟机中,然后加载RabbitMQ镜像
docker load -i /usr/local/mq.tar
- 启动RabbitMQ容器
docker run -e RABBITMQ\_DEFAULT\_USER=root -e RABBITMQ\_DEFAULT\_PASS=root -v mq-plugins:/plugins --name mq --hostname mq -p 15672:15672 -p 5672:5672 -d rabbitmq:3-management
输入虚拟机的ip和开放的端口,即可访问RabbitMQ的管理后台:
RabbitMQ管理后台介绍
下图是RabbitMQ管理后台的预览页面,展示了RabbitMQ节点的相关信息,如节点的名字、状态、运行时间等
下图Connections(连接)页面,在这个页面查看、管理和关闭当前所有的TCP连接。
下图是Channels(通道)页面,这里展示了所有当前打开的通道以及它们的详细信息
下图是Exchanges(交换机)页面,这里可以查看、创建和删除交换机。交换机是RabbitMQ消息路由的重要组成部分,它决定了消息如何被路由到正确的队列。
下图是Queues(队列)页面,可以在这里看到所有的队列。队列是RabbitMQ的核心,它保存了所有待处理的消息。
下图是Admin(管理)页面,在这里可以管理RabbimtMQ的用户,并分配相关功能。为了给不同的用户授权不同的功能,RabbitMQ设计了一个virtual host(虚拟主机)的概念,每个用户只能看到它所在虚拟主机下的资源。virtual host是对queue、exchange等资源的逻辑分组。
下面是RabbitMQ官方关于如何监控RabbitMQ以及RabbitMQ管理后台的介绍。
如何监控RabbitMQ
RabbitMQ的管理插件介绍
RabbitMQ相关概念
下图是AMQP的通讯模型,由消息发送者、消息接收者、交换机、队列组成。
- 消息发送者:发送消息
- 消息接收者:消费消息
- 交换机:路由消息,决定消息路由到哪个队列
- 队列:负责存储消息
下图是RabbitMQ对于AMQP通讯模型的实现。
RabbitMQ中常见的通讯模型主要可以分为两种,队列和发布/订阅,而这两种又可以往下细分。
- 队列
- 基本消息队列
- 工作消息队列
- 发布订阅,根据交换机类型不同可以分为三种
- Fanout Exchange:广播
- Direct Exchange:路由
- Topic Exchange:主题
使用
下面介绍RabbitMQ中简单队列的使用。
消息发布者代码
public class Send {
private static final String QUEUE\_NAME = "hello";
public static void send() {
//建立和RabbitMQ Server的连接
ConnectionFactory connectionFactory = new ConnectionFactory();
connectionFactory.setHost("192.168.200.215");
connectionFactory.setUsername("root");
connectionFactory.setPassword("root");
try (Connection connection = connectionFactory.newConnection()) {
//创建通道
Channel channel = connection.createChannel();
channel.queueDeclare(QUEUE\_NAME, false, false, false, null);
String message = "Hello World1";
//发送消息
channel.basicPublish("", QUEUE\_NAME, null, message.getBytes());
} catch (IOException e) {
e.printStackTrace();
} catch (TimeoutException e) {
e.printStackTrace();
}
}
public static void main(String[] args) {
send();
}
}
消息接收者代码
public class Recv {
private static final String QUEUE\_NAME = "hello";
public static void receive() {
ConnectionFactory factory = new ConnectionFactory();
factory.setHost("192.168.200.215");
factory.setUsername("root");
factory.setPassword("root");
try(Connection connection = factory.newConnection()) {
Channel channel = connection.createChannel();
//这里声明队列是因为,消费者有可能先启动,此时要确保有队列,才能尝试从队列中获取消息
channel.queueDeclare(QUEUE\_NAME, false, false, false, null);
DeliverCallback callback = new DeliverCallback() {
@Override
public void handle(String s, Delivery delivery) throws IOException {
String message = new String(delivery.getBody(), "UTF-8");
System.out.println("receive message: " + message);
}
**自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。**
**深知大多数大数据工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!**
**因此收集整理了一份《2024年大数据全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。**
![img](https://img-blog.csdnimg.cn/img_convert/2622f1f3296214116c9c006e9814e566.png)
![img](https://img-blog.csdnimg.cn/img_convert/3b4710795b888dbf4e7394d962d72c87.png)
![img](https://img-blog.csdnimg.cn/img_convert/498d41972f91e217d93a8d4ec631cb8d.png)
![img](https://img-blog.csdnimg.cn/img_convert/893746f952cf7efa64a5db92c9217bc3.png)
![img](https://img-blog.csdnimg.cn/img_convert/7fcfd003321c4b19ac90f0a45316f0ec.png)
**既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上大数据开发知识点,真正体系化!**
**由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新**
**如果你觉得这些内容对你有帮助,可以添加VX:vip204888 (备注大数据获取)**
![img](https://img-blog.csdnimg.cn/img_convert/451aa7801321455048771305338b79f9.png)
5%以上大数据开发知识点,真正体系化!**
**由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新**
**如果你觉得这些内容对你有帮助,可以添加VX:vip204888 (备注大数据获取)**
[外链图片转存中...(img-vvnarB10-1712853120074)]