RabbitMQ--十七问
- rabbitmq 使用场景有哪些
- rabbitmq 有哪些重要的角色
- rabbitmq 有那些重要的组件
- rabbitmq 中vhost的作用是什么
- rabbitmq 的消息是怎么发送的
- rabbitmq 怎么保证消息的稳定性
- rabbitmq 怎么避免消息丢失
- rabbitmq 要保证消息持久化成功的条件有哪些
- rabbitmq 持久化有什么缺点
- rabbitmq 有几种广播类型
- rabbitmq 怎么实现延迟消息队列
- rabbitmq 集群有什么用
- rabbitmq 节点的类型
- rabbitmq 集群搭建需要注意哪些问题
- rabbitmq 每个节点都是其他节点的完整拷贝吗?为什么
- rabbitmq 集群中唯一一个磁盘节点崩溃了会发生什么情况
- rabbitmq 对集群节点停止顺序有要求吗
rabbitmq 使用场景有哪些#
1.跨系统的异步通信,所有需要异步交互的地方都是可以使用消息队列。就像我们除了打电话(同步)以外,还需要发短信,发电子邮件(异步)的通信方式。
2.多个应用之间的耦合,由于消息是平台无关和语言无关的,而且语义上也不再是函数调用,因此更适合作为多核应用之间的松耦合的接口。基于消息队列的耦合,不需要发送方和接收方同时在线,在企业应用集成(EAL)中,文件传输,共享数据,消息队列,远程过程调用都是可以作为集成的方法。
3.应用内的同步便一步,比如订单处理,就可以由前端应用将订单信息放到队列,后端应用从队列里依次获得消息处理,高峰时的大量订单可以积压在队列里慢慢处理掉。由于同步通常意味着阻塞,而大量线程的阻塞会降低计算机的性能。
4.消息驱动的架构,系统分解为消息队列,和消息制造者和消息消费者,一个处理流程可以根据需要拆成多个阶段,阶段之间用队列连接起来,前一个阶段处理的结果放入队列,后一个阶段从队列中获取消息继续处理。
5.应用需要更灵活的耦合方式,如发布订阅,比如可以指定路由规则。
6.夸局域网,甚至跨越城市的通讯,比如北京机房与广州机房的应用程序的通信。
rabbitmq 有哪些重要的角色#
RabbitMQ 中重要的角色有:生产者,消费者和代理:
- 生产者:消息的创建者,负责创建和推送数据到消息服务器;
- 消费者:消息的接收方,用于处理数据和确认消息;
- 代理:就是rabbitMQ本身,用于扮演“快递员”的角色,本身不生产消息,只是扮演“快递员”的角色
rabbitmq 有那些重要的组件#
- ConnectionFactory(连接管理器):应用程序与rabbitmq之间建立连接的管理器,程序代码中使用
- Channel(管道):消息推送使用的通道。
- Exchange(交换器):用于接受、分配消息、
- Queue(队列):用于存储生产者的消息。
- RoutingKey(路由键):用于把生产者的数据分配到交换器上
- BindingKey(绑定键):用于把交换器的消息绑定到队列上
rabbitmq 中vhost的作用是什么#
vhost可以理解为虚拟broker,即mini-RabbitMQ server。其内部均含有独立的queue、exchange和binding等,但最最重要的是,其拥有独立的权限系统,可以做到vhost范围的用户控制。当然,从RabbitMQ的全局角度,vhost可以作为不同权限隔离的手段(一个典型的例子就是不同的应用可以跑在不同的vhost中)。
rabbitmq 的消息是怎么发送的#
首先客户端必须连接到RabbitMQ服务器才能发布和消费消息,客户端和rabbit server之间会创建一个tcp连接,一旦tcp打开并通过了认证(认证就是账号和密码),你的客户端和rabbitmq就创建了一条amqp信道(channel),信道是创建在“真实”tcp上的虚拟机连接,amqp命令都是通过信道发送出去的,每个信道都会有一个唯一的id,不论是发布消息,订阅队列都是通过这信道完成的。
rabbitmq 怎么保证消息的稳定性#
提供了事务的功能。
通过将channel设置confirm(确认)模式
rabbitmq 怎么避免消息丢失#
1.消息持久化
2.ACK确认机制
3.设置集群镜像模式
4.消息补偿机制
rabbitmq 要保证消息持久化成功的条件有哪些#
1.声明队列必须设置持久化durable设置为true
2.消息推送投递模式设置持久化,deliveryMode 设置为2(持久)
3.消息已经到达持久化交换器
4.消息已经到达持久化队列
满足以上四个条件才能保证消息华持久化成功
rabbitmq 持久化有什么缺点#
持久化的缺点就是降低了服务器的吞吐量,因为是用的诗词哦按而非内存存储,从而降低了吞入量,可以尽量使用SSD硬盘来缓解吞吐量的问题。
rabbitmq 有几种广播类型#
三种广播类型:
- fanout:所有bind到此exchange的queue都可以接收到消息(纯广播,绑定到rabbitmq的接受者都能接收到消息)
- direct:通过routingKey和exchange决定的那个唯一的queue可以接收消息
- topic:所有符合routingKey(此时可以是一个表达式)的routingKey所有bind的queue可以接收到消息
rabbitmq 怎么实现延迟消息队列#
1.通过消息过期后进入死信交换器,在有交换器转发到延迟消费队列,实现延迟功能
2.使用rabbitmq-delayed-message-exchange插件实现延迟功能
rabbitmq 集群有什么用#
集群主要有以下两个用途
高可用:某个服务器出现问题,整个Rabbitmq还可以继续使用
高容量:集群可以承载更多的消息量。
rabbitmq 节点的类型#
磁盘节点: 消息存储到磁盘
内存节点:消息存储在内存,性能高于磁盘类型,但是重启服务器会丢失消息
rabbitmq 集群搭建需要注意哪些问题#
各节点之间使用“--link”连接,此属性不能忽略。
各节点使用的erlang cookie值必须相同,此值相当于“密钥”的功能,用于各个节点的认证,整个及群众必需包含一个磁盘节点。
rabbitmq 每个节点都是其他节点的完整拷贝吗?为什么#
不是,原因有以下两个:
1.存储空间的考录:如果每个接电脑都拥有所有对列的完全拷贝,这样新增节点不但没有新增存储空间,反而增加了更多的冗余数据。
2.性能的考虑:如果每条消息都需要完整拷贝到每一个集群节点,那新增节点并没有提升处理消息的能力,最多是保持和单节点相同的性能甚至是更糟。
rabbitmq 集群中唯一一个磁盘节点崩溃了会发生什么情况#
如果唯一磁盘的磁盘节点崩溃了,不能进行以下操作:
不能创建队列
不能创建交换器
不能创建绑定
不能添加用户
不能更改权限
不能添加和删除集群节点
唯一次哦按节点崩溃了,集群是可以保持运行的,但你不能更改任何东西
rabbitmq 对集群节点停止顺序有要求吗#
rabbitmq 对集群的停止的顺序是有要求的,应该先关闭内存节点,最后再关闭此盘及诶单,如果顺序恰好相反,可能会导致消息丢失。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本