常用的消息中间件(ActiveMQ、RabbitMQ、RocketMQ、Kafka)面试精华

目录

主要作用:

四种消息中间件:

主要作用:

  • 解耦
  1. 多个系统调用主系统可选择是否订阅
  • 异步
  1. 主系统可提高响应时间
  • 削峰
  1. 通过消息队列减轻消息访问对服务器的压力

四种消息中间件:

ActiveMQ

  1. 万级吞吐量

RabbitMQ(中小型公司)

  1. 万级吞吐量

RocketMQ(中大型公司)(非分布式)

  1. 十万级

  2. Topic主题分类更加细致 有Tag分级

  3. 高可用:镜像集群模式

  4. 怎么做:开启镜像集群策略,可指定同步数据节点数量是所有还是个别几个

Kafka(纯分布式的mq)

  1. 十万级

  2. 高可用:假设一个topic有三个partition,在topic中写三条消息,每条消息存在不同的partition中,每个partition有自己的副本,选出leader和follower,leader宕机后,在follower中选出leader

  3. 只能leader读写,保证一致性,减轻复杂度

  4. leader读取数据后,follower从leader拉取数据,响应ack告诉leader

  5. 生产者给kafka发送消息都有一个offset 在kafka中是有序的,消费者也是按照顺序消费的,消费者按顺序消费到哪个offset,zookeeper有记录,kafka可以从zookeeper中读取消费到那个位置了

  6. 由于消费者重启,kafka无法感知消费者消标记的offset,kafka会重复发已经发过的消息,导致消费者会重复消费 需要要保证幂等性

解决办法:

每条消息设置id存入Redis

数据库主键唯一性

相关推荐
努力发光的程序员3 小时前
互联网大厂Java面试:从Spring Boot到微服务架构
spring boot·缓存·微服务·消息队列·rabbitmq·spring security·安全框架
2501_941147425 小时前
基于 Kotlin 与 Ktor 构建高并发微服务与异步分布式系统实践分享
rabbitmq
debug骑士9 小时前
面向云原生微服务的Go高并发架构实践与性能优化工程化经验分享案例研究
rabbitmq
2501_9418024810 小时前
Java高性能微服务架构与Spring Boot实战分享:分布式服务设计、负载均衡与优化经验
rabbitmq
2501_9411474215 小时前
高并发日志系统ELK/Fluentd/ClickHouse在互联网优化实践经验分享
rabbitmq
JSON_L1 天前
Fastadmin 使用RabbitMQ队列
rabbitmq·php·fastadmin
2501_941225681 天前
Go语言高性能API网关设计与gRPC实战分享:微服务接口优化与负载均衡经验
rabbitmq
源码梦想家1 天前
面向未来软件工程实践:基于Go语言的高并发架构设计思考与经验分享案例分析研究方法探讨
rabbitmq
2501_941147711 天前
高并发CDN与边缘计算在互联网系统优化实践经验分享
rabbitmq
2501_941143731 天前
分布式日志系统与可观测性在高并发互联网系统架构优化与实践分享
rabbitmq