美文网首页Java 杂谈互联网科技分布式
后端技能树修炼:基于队列的流量削峰模式

后端技能树修炼:基于队列的流量削峰模式

作者: 像程序一样思考 | 来源:发表于2018-09-28 19:58 被阅读14次

在分布式架构中,前端一个请求会经过后端的多个服务的处理才返回结果,这时就可能会存在一种情况,在间歇性高负载情况下,某个服务 B 的处理能力不能满足负载的需求,从而导致服务 B 崩溃或者服务调用者 A 响应超时,如下图所示:

那么如何解决这种问题呢?有读者可能会说,那就给服务 B 作单机性能优化,从而提升单机处理能力,进而提升服务 B 集群的整体处理能力;或者当单机处理能力已经无法进一步优化或者即使优化后仍然无法满足负载需求时,那么就对服务 B 集群进行水平扩容,从而提升集群整体的处理能力。

没错,这是一种常见的解决方案,但如果服务 B 集群扩容成本很高呢?例如服务 B 需要用到 GPU 来跑 AI 模型,而我们知道 GPU 成本不低。有一种解决方案是通过引入消息队列(例如 Kafka,RabbitMQ 等)来作为缓冲区,从而最小化请求峰值对服务可用性和响应性的影响(当然,也要考虑具体业务场景是否适合使用这种方式),如下图所示:

引入消息队列后,原来的同步调用变为异步执行,服务 A 将原来的请求封装成消息,发送到消息队列中,而服务 B 则根据自己的处理节奏从消息队列中获取消息进行处理,消息队列起到缓冲区的作用。这样即使服务 A 集群对服务 B 集群发起大量的并发请求,也不会导致服务 B 集群处理不过来甚至崩溃。

当然这种模式也适用于进程内的流量削峰,我们只需把上面的服务 A 和服务 B 替换成同一个应用进程内的模块间调用,而消息队列则替换成进程内的队列实现方案(例如 Disruptor)即可,模式是活的,具体如何应用就看使用者的水平了

相关文章

  • 后端技能树修炼:基于队列的流量削峰模式

    在分布式架构中,前端一个请求会经过后端的多个服务的处理才返回结果,这时就可能会存在一种情况,在间歇性高负载情况下,...

  • springboot集成rabbitmq商品秒杀业务实战(流量削

    消息队列如何实现流量削峰? 要对流量进行削峰,最容易想到的解决方案就是用消息队列来缓冲瞬时流量,把同步的直接调用转...

  • Redis实现发布订阅模式

    简述 Redis可作为消息队列中间件使用,属于发布订阅模式 消息队列可以实现【系统解耦】、【异步处理】、【流量削峰...

  • 基于Go的Rabbitmq实践

    学会使用消息队列是后端程序员进阶的必备技能之一,消息队列可以异步处理请求,缓解系统的压力,从而达到解耦、削峰等目的...

  • 消息队列

    为什么要使用消息队列? 主要用于三个场景 解耦 异步 削峰 解耦 传统模式: 异步 传统模式: 削峰 传统模式: ...

  • rabbitmq实例:订单系统

    流量削峰 消息队列的一个主要用途是做流量削峰。比如一台单点服务器,平时的访问量很少,但如果做秒杀活动,流量的突然剧...

  • 该如何选择消息队列?

    在高并发业务场景下,消息队列在流量削峰、解耦上有不可替代的作用。当前使用较多的消息队列有 RabbitMQ、Roc...

  • Redis 队列

    队列的实现 举例: 队列主要用在系统解耦、流量削峰、异步处理、数据顺序处理等场景。新手在使用时可能会犯...

  • 2019-05-31(RABBIT_MQ)

    RABBIT_MQ是消息队列,即messge queue 作用:模块之间的解耦、流量削峰、异步消息和消息通信;高性...

  • php-消息队列

    主要内容 1.消息队列的概念,原理和场景2.解耦案例:队列处理订单系统和配送系统3.流量削峰案例:Redis的Li...

网友评论

    本文标题:后端技能树修炼:基于队列的流量削峰模式

    本文链接:https://www.haomeiwen.com/subject/cafmoftx.html