2021-12-07 SpringCloud学习

服务雪崩

  多个服务之间调用时,假设服务A调用服务B和服务C,服务B和服务C又调用其他的微服务,这就是所谓的“扇出“、如果扇出的链路上某个微服务的调用时间过长或者不可用,对服务A的调用就会占用越来越多的系统资源,进而引起系统崩溃,所谓的雪崩效应。

  对于高流量的应用来说,单一的后端依赖可能会导致所有服务器上的所有资源都在几秒钟内饱和,比失败更糟糕的是,这些应用程序还可能导致服务之间的延迟,备份队列,线程和其他资源的紧张,导致整个系统发生更多级联故障,这些都表示需要对故障和延迟进行隔离和管理,以便单个依赖关系的失败,不能取消整个应用程序或系统

  通俗的说就是 ·弃车保帅·

 


 

Hystrix

  Hystrix是一个用于处理分布式系统的延迟和容错的开源库。在分布式系统里,许多依赖不可避免的会调用失败,比如超时,异常等。Hystrix能够保证在一个依赖出问题的情况下,不会导致整体服务失败,避免级联故障,以提高分布式系统的弹性。

  ”断路器“本身是一种开关装置,当某个服务单元发生故障后,通过断路器的故障监控(类似熔断保险丝),向调用方法返回一个服务预期的,可处理的备选响应(FallBack),而不是长时间的等待或者抛出调用方法无法处理的异常,这样就可以保证了服务调用方法的线程不会被长时间的不必要的占用,从而避免了故障在分布式系统中的蔓延,乃至雪崩。

能干嘛:

·服务降级

·服务熔断

·服务限流


 

服务熔断(服务端)

  对雪崩效应的一种微服务链路保护机制。

  当扇出链路的某个微服务不可用或者响应时间太长时,会进行服务的降级,进而熔断该节点微服务的调用,快速返回错误的响应信息(5秒内20次调用失败就会启用熔断机制)注解:@HystixCommand

posted @ 2021-12-07 23:15  努力努力再努力W  阅读(33)  评论(0)    收藏  举报