初始MQ(十一)
1 同步通讯
例如:微信视频电话
优点:时效性较强,可以立即得到结果;
同步调用存在的问题:
- 耦合度高,每次加入新的需求,都要修改原来的代码;
- 性能和吞吐能力下降,调用者需要等待服务提供者响应,如果调用链过长则响应时间等于每次调用的时间之和;
- 资源浪费,调用链中的每个服务在等到响应过程中,不能释放请求占用的资源,高并发场景下会极度浪费系统资源;
- 级联失败,如果服务提供者出现问题,所有调用方都会跟着出问题,如同多米诺骨牌一样,迅速导致整个微服务群故障。
2 异步通讯
例如:微信文字聊天
异步调用方案:异步调用常见实现就是事件驱动模式;
优势:服务解耦,耦合度低;性能提升,吞吐量提高;服务没有强依赖,不担心级联失败问题,故障隔离;流量削峰;
缺点:依赖于Broker的可靠性、安全性、吞吐能力;架构复杂了,业务没有明显的流程线,不好追踪管理。
3 MQ常见框架
3.1 什么是MQ
MQ(MessageQueue),中文是消息队列,字面来看就是存放消息的队列。也就是事件驱动架构中的Broker。
RabbitMQ | ActiveMQ | RocketMQ | Kafka | |
公司/社区 | Rabbit | Apache | 阿里 | Apache |
开发语言 | Erlang | Java | Java | Scala&Java |
协议支持 | AMQP,XMPP,SMTP,STOMP | OpenWire,STOMP,REST,XMPP,AMQP | 自定义协议 | 自定义协议 |
可用性 | 高 | 一般 | 高 | 高 |
单机吞吐量 | 一般 | 差 | 高 | 非常高 |
消息延迟 | 微秒级 | 毫秒级 | 毫秒级 | 毫秒以内 |
消息可靠性 | 高 | 一般 | 高 | 一般 |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?