JAVA中熔断和降级真实关系是什么

发布时间:2021-09-03 13:15:00 作者:小新
来源:亿速云 阅读:109

这篇文章将为大家详细讲解有关JAVA中熔断和降级真实关系是什么,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

降级

什么是服务降级呢?降级主要有以下几种情况

看到这,相信你已经看到了一个相同点,就是以上三者(超时、不可用、限流)触发时,都会走同一个逻辑,那就是降级逻辑,在hystrix里面叫做fallback;

JAVA中熔断和降级真实关系是什么

熔断

什么是服务熔断

熔断很好理解,就是一个断开的过程;

熔断就像是家里的保险丝一样,当电流达到一定条件时,比如保险丝能承受的电流是5A,如果你的电流达到了6A,因为保险丝承受不了这么高的电流,保险丝就会融化,这时候电路就会断开,起到了保护电器的作用;

在微服务里面也是一样,当下游的服务因为某种原因突然变得不可用或响应过慢,上游服务为了保证自己整体服务的可用性,不再继续调用目标服务,直接返回,快速释放资源。如果目标服务情况好转则恢复调用;

熔断和降级的关系

说了那么多,其实也能想到了,降级和熔断其实就是服务安全中的2个不同的流程,在服务发生故障时,肯定是先断开(熔断)与服务的连接,然后在执行降级逻辑;

JAVA中熔断和降级真实关系是什么

那既然不管怎样都会执行降级逻辑,这时候就可以理解为 降级是一种设计思想,在java层面就是一个接口,而熔断是降级的不同实现方式,他们的关系如下图:

JAVA中熔断和降级真实关系是什么

降级方式

那么我们现在知道降级是一个接口了,接下来在看看他们的实现方式是怎样的吧

1、熔断降级(不可用)

熔断逻辑是这样的,A服务调用B服务,失败次数达到一定阈值后 ,A服务的断路器打开,就不在请求B服务,而是直接执行本地的fallback方法;这种叫做熔断降级,看到这里,也许你已经明白了,熔断只是降级的其中一种实现方式;

JAVA中熔断和降级真实关系是什么

2、超时降级

同样是A服务调用B服务,B服务响应超过了A服务设定的阈值后,就会执行降级逻辑;

JAVA中熔断和降级真实关系是什么

3、限流降级

同样是A服务调用B服务,服务A的连接已超过自身能承载的最大连接数,比如说A能承载的连接数为5,但是目前的并发有6个请求同时进行,前5请求能正常请求,最后一个会直接拒绝,执行fallback降级逻辑;

JAVA中熔断和降级真实关系是什么

关于“JAVA中熔断和降级真实关系是什么”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

推荐阅读:
  1. springcloud hystrix(监控、熔断、降级)
  2. java和jvm是什么关系

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

java

上一篇:php如何判断数组元素不为空格

下一篇:MySQL中的隐藏列的具体查看方法

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》