熔断:

摘自:https://www.cnblogs.com/yawen/p/6655352.html

雪崩:

雪崩效应:是一种因 服务提供者 的不可用导致 服务调用者 的不可用,并将不可用逐渐放大的过程

  正常情况下的服务

熔断:_第1张图片

某一服务如:DependcyI 出现异常,拖垮整个服务链路,消耗整个线程队列,造成服务不可用,资源耗尽:

熔断:_第2张图片

雪崩的原因:

  形成过程:

           1)服务提供者不可用    

                             a)硬件故障:硬件损坏造成的服务器主机宕机, 网络硬件故障造成的服务提供者的不可访问

                             b)程序Bug:

                             c)   缓存击穿:缓存击穿一般发生在缓存应用重启, 所有缓存被清空时,以及短时间内大量缓存失效时. 大量的缓存不命中, 使请求直击后端,造成服务提供者超负荷运行,引起服务不可用

                             d)用户大量请求:在秒杀和大促开始前,如果准备不充分,用户发起大量请求也会造成服务提供者的不可用

           2)重试加大流量

                             a)用户重试:在服务提供者不可用后, 用户由于忍受不了界面上长时间的等待,而不断刷新页面甚至提交表单

                             b)代码逻辑重试: 服务调用端的会存在大量服务异常后的重试逻辑

           3)服务调用者不可用

                         a)同步等待造成的资源耗尽:当服务调用者使用同步调用 时, 会产生大量的等待线程占用系统资源. 一旦线程资源被耗尽,服务调用者提供的服务也将处于不可用状态, 于是服务雪崩效应产生了。

 

二、概念

  1. 服务熔断
              一般是指软件系统中,由于某些原因使得服务出现了过载现象,为防止造成整个系统故障,从而采用的一种保护措施,所以很多地方把熔断亦称为过载保护。很多时候刚开始可能只是系统出现了局部的、小规模的故障,然而由于种种原因,故障影响的范围越来越大,最终导致了全局性的后果。
    适用场景:防止应用程序直接调用那些很可能会调用失败的远程服务或共享资源
  2. 服务降级:
              当服务器压力剧增的情况下,根据当前业务情况及流量对一些服务和页面有策略的降级,以此释放服务器资源以保证核心任务的正常运行。

你可能感兴趣的:(网络)