微服务【SpringCloud】--熔断器Hystrix



熔断器Hystrix简介

(1)熔断器是什么?

熔断器(fuse)是指当电流超过规定值时,以本身产生的热量使熔体熔断,断开电路的一种电器,如(空气开关)

(2)什么是Hystrix

美[hɪst’rɪks]
Hystrix是一个延迟和容错库

(3)Hystrix有什么作用?

使用服务降级,线程隔离解决雪崩问题
在这里插入图片描述

雪崩问题

  • (1) 微服务I 发生异常,请求阻塞,用户请求就不会得到响应,则tomcat的这个线程不会释放,于是越来越多的用户请求到来,越来越多的线程会阻塞,会导致服务器资源耗尽,从而导致所有其它服务都不可用,形成雪崩效应。
  • (2)Hystrix解决雪崩问题的手段主要是服务降级
    线程隔离
    服务熔断
    在这里插入图片描述
    在这里插入图片描述

线程隔离

(1) 线程隔离是什么?
Hystrix为每个依赖服务调用分配一个小的线程池
如果线程池已满调用将被立即拒绝,默认不采用排队,加速失败判定时间。
在这里插入图片描述

服务降级

优先保证核心服务,而非核心服务不可用或弱可用。用户的请求故障时,不会被阻塞,更不会无休止的等待或者看到系统崩溃,至少可以看到一个执行结果(例如返回友好的提示信息) 。
服务降级虽然会导致请求失败,但是不会导致阻塞,而且最多会影响这个依赖服务对应的线程池中的资源,对其它服务没有响应。

服务降级实践

(1)读音
circuit 美[ˈsɜːrkɪt]
(2)服务熔断配置

  • 1 配置依赖
  • 2 开启熔断

在启动类上添加注解:@EnableCircuitBreaker

  • 3 编写降级方法 myFallBack
  • 4 设置Controller方法的降级方法为 myFallBack
    @HystrixCommand(fallbackMethod = “myFallBack”)

pom.xml


    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring-cloud.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
                <version>2.2.6.RELEASE</version>
            </dependency>
        </dependencies>

启动器类
@SpringCloudApplication

CumtomerController

1:未使用统一的 退路方法

@HystrixCommand(fallbackMethod = "fallback")
    public Object get(@PathVariable long id)
 //退路
    public Object fallback(long id){
        return "不好意思,网络卡,十分卡";
    }
    //只是让请求的数据返回,让线程被释放掉```2:使用统一的 退路方法

```java
@DefaultProperties(defaultFallback = "defaultFallback")
@Slf4j
public class CustomerController

@HystrixCommand 找@DefaultProperties(defaultFallback = “defaultFallback”) ,再找到defaultFallback方法

@DefaultProperties

(1)DefaultProperties注解 用来指定 默认的降级方法

标记在类上

(2)属性defaultFallback

设置降级方法

(3)与@HystrixCommand 配合使用

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值