消息队列作用和选型

消息队列的作用

消息队列用于不同系统和服务间的通信,在目前的大型应用中都需要依赖消息队列构建更易于维护性能更高的系统,消息队列的主要作用包括:

  • 解耦: 减少系统之间的依赖关系,例如直接将两个功能通过编码写在同一个服务中完成一个功能之后再执行第二功能的程序,或者使用RPC方式调用其他服务等待调用结果等,这些方案都将功能耦合在一起,使两个功能需要同时完成,不利用业务的扩展。
  • 异步:异步能提高系统的响应速度,减少用户等待时间。
  • 削峰限流:消息队列可以看做是一个任务队列,它能提供很大的容量,当系统流量过大时,将请求放入消息队列,以大量内存以及一定的延迟,保证系统的稳定性。

消息队列的缺点

  • 消息队列会引入延迟

  • 提高系统的复杂度: 使用MQ需要解决消息重复消费,消息丢失,消息有序性等问题。

  • 事务一致性:通过消息队列链接的系统之间,可能会出现数据不一致,需要提供事务方案,

  • 增加运维难度

消息队列选型

  • RocketMQ:RokcetMQ吞吐量高,时延低,支持集群,功能丰富。使用Java语言开发,比较容易扩展和二次开发,适合在线系统。
  • Kafka:Kafka吞吐量极高,延迟高,使用异步批量设计,适合实时性不高的离线业务。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值