Hystrix入门使用 服务熔断 服务降级 服务雪崩

这篇具有很好参考价值的文章主要介绍了Hystrix入门使用 服务熔断 服务降级 服务雪崩。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、概念

hystrix停止更新,理念优秀。

分布式系统面临的问题:

  • 对于复杂的分布式体系,有数十个依赖,依赖不可避免的错误。

  • 服务会出现雪崩,高可用受到破坏

    Hystrix就是用于解决分布式系统延迟和容错的开源库。

  • 保证在一个依赖出现问题,不会导致整体的服务失败,避免级联故障,以提高分布式系统的弹性

  • 如果出现错误,向调用方抛出备选FallBack

1. 功能

  • 服务降级
  • 服务熔断
  • 接近实时监控
  • 服务限流
  • 服务隔离

停止更新进入维护

2. 重要理念

服务降级

服务器出现问题时候,不让客户端持续等待,立刻返回一个友好的提示。fallback.

以下原因会导致服务降级.

  • 程序运行异常
  • 服务熔断触发降级
  • 线程池和信号量打满
  • 程序超时

服务熔断

当访问达到最大访问(简短可以理解为保险丝),直接拒绝访问,然后调用服务降级方法,返回友好提示。

降级-熔断-恢复

服务限流

秒杀高并发的操作,严禁一窝蜂过来拥挤,有序进行。


二、Hystrix案例

Hystrix一般用于消费端,也就是调用端;

1. 服务降级

什么时候开启服务降级呢?

  1. 当被调用服务超时
  2. 当被调用服务Down机
  3. 当调用这等待时间小于服务端的处理时间

1.1 创建服务端

 <dependencies>
        <!--新增hystrix-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
        </dependency>


        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>

        <dependency>
            <groupId>com.atjianyi</groupId>
            <artifactId>cloud-api-commons</artifactId>
            <version>1.0-SNAPSHOT</version>
        </dependency>


        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>

        <!--        <dependency>-->
        <!--            <groupId>org.springframework.boot</groupId>-->
        <!--            <artifactId>spring-boot-devtools</artifactId>-->
        <!--            <scope>runtime</scope>-->
        <!--            <optional>true</optional>-->
        <!--        </dependency>-->

        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>
  1. 创建mould 8001端口,且注册进入eureka

Hystrix入门使用 服务熔断 服务降级 服务雪崩

  1. 在业务当中添加两个方法: 方便我们后续进行服务降级和熔断时候对比。
    • ok模拟正常业务
    • timeout模拟长流程业务员

Hystrix入门使用 服务熔断 服务降级 服务雪崩

1.2 添加客户端

出现客户端相应缓慢,8001同一层次的其他接口被困死,因为在tomcat线程池当中默认只有10个线程。

客户端服务的核心就是调用远程服务。

Hystrix入门使用 服务熔断 服务降级 服务雪崩

使用Jemeter测试,压测timeout方法,发现OK方法也出现了问题,相应变慢,我们应该怎么来改善这一问题,这就引入了我们下面要说的Hystrix;

1.3 Hystrix解决

  • 超时导致服务器变慢
  • 出错(程序运行出错)

解决方案:

  • 对方超时,必须有服务降级
  • 对方down机,必须服务降级
  • 对方OK,调用者自己出故障,自己处理降级

@HystrixCommand(fallbackMethod)

EnableCirutBreaker

1.3.1 提供端降级
  1. 在 Timeout 业务当中添加注解

Hystrix入门使用 服务熔断 服务降级 服务雪崩

  @Override
    @HystrixCommand(fallbackMethod = "timeoutHandler" ,commandProperties = {
            @HystrixProperty(name="execution.isolation.thread.timeoutInMilliseconds",value = "3000") //表示业务处理若超过 3s,则降级,调用方法。
    })
    public String timeout(String id ) {
        int tmm = 3*1000;
        try {
            Thread.sleep(tmm);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        return "payment-timeout"+"current Thread "+Thread.currentThread().getId()+"   cID="+id;
    }

    /**
     * 降级回调方法
     * @param id
     * @return
     */
    public String timeoutHandler(String id){
        return "payment-timeout-handler"+"current Thread "+Thread.currentThread().getId()+"   cID="+id;
    }
  1. 主启动类当中激活 @EnableCircuitBreaker
@SpringBootApplication
@EnableEurekaClient
@EnableCircuitBreaker
public class HystrixPaymentApplication {
    public static void main(String[] args) {
        SpringApplication.run(HystrixPaymentApplication.class,args);
    }
}

测试结果

由于配置了hystrix容忍 3s 的超时,实际业务需要 5s 所以这里服务进行了降级处理。

Hystrix入门使用 服务熔断 服务降级 服务雪崩

现在我们把 timeout() 代码改成如下,在进行测试: 结果显示降级并且调用到了降级方法。

 @Override
    @HystrixCommand(fallbackMethod = "timeoutHandler" ,commandProperties = {
            @HystrixProperty(name="execution.isolation.thread.timeoutInMilliseconds",value = "3000") //表示业务处理若超过 3s,则降级,调用方法。
    })
    public String timeout(String id ) {
        //直接报错,观察是否会进行降级
        int t = 10/0;
        int tmm = 5*1000;
        try {
            Thread.sleep(tmm);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        return "payment-timeout"+"current Thread "+Thread.currentThread().getId()+"   cID="+id;
    }

Hystrix入门使用 服务熔断 服务降级 服务雪崩


1.3.2 客户端降级
server:
  port: 80
spring:
  application:
    name: cloud-hystrix-order
eureka:
  client:
    register-with-eureka: true    #表示不向注册中心注册自己
    fetch-registry: true   #表示自己就是注册中心,职责是维护服务实例,并不需要去检索服务
    service-url:
      #设置与eureka server交互的地址查询服务和注册服务都需要依赖这个地址
      defaultZone: http://localhost:7001/eureka/
#      defaultZone: http://eureka7001.com:7001/eureka,http://eureka7002.com:7002/eureka

feign:
  hystrix:
    enabled: true
ribbon:
  ReadTimeout: 5000
  ConnectionTimeout: 5000

这里我们将主调用方法的超时容忍设为 1.5s, 而远程调用的长流程业务需要 3s完成,因此,测试一样会降级处理。

 @GetMapping("consumer/payment/timeout/{id}")
    @HystrixCommand(fallbackMethod = "timeoutHandler",commandProperties = {
            @HystrixProperty(name = "execution.isolation.thread.timeoutInMilliseconds",value = "1500") //设置容忍度为1500
    })
    public R timeout(@PathVariable("id")String id){
        R ok = paymentClient.timeout(id);
        return ok;
    }
    public R timeoutHandler(String id){
        R<String> r = new R<>();
        r.setData("consumer-timeoutHandler  id="+id);
        return r ;
    }

Hystrix入门使用 服务熔断 服务降级 服务雪崩

然而,上述代码的写法带来的两个问题

  • 代码膨胀:每个方法都有一个hystrixConnmend,若有一百个接口,就得写一百个@hystrix…
  • 代码混乱: 服务降级和正常业务逻辑进行了混淆

针对上面出现的两个问题,我们改写为下面的方法。

1.4 全局服务降级

全局服务降级配置,就是针对需要服务降级的进行通用配置 使用 @Defaultproperties()注解进行配置;

再改写消费端如下,配置全局服务降级;

Hystrix入门使用 服务熔断 服务降级 服务雪崩

Hystrix入门使用 服务熔断 服务降级 服务雪崩

通过上一个配置,我们解决了代码膨胀得问题,接着我们最后写出一套完整通用得服务调用与降级的Demo。

1.5 究极服务降级

  1. 在 client 接口当中直接指定降级处理类;

Hystrix入门使用 服务熔断 服务降级 服务雪崩

  1. 继承 client接口,并且实现方法。

Hystrix入门使用 服务熔断 服务降级 服务雪崩

在测试的时候,将 服务端(被调用端)关闭,成功调用降级方法!

Hystrix入门使用 服务熔断 服务降级 服务雪崩

这样,我们就解决了代码膨胀和代码混乱的问题;


2. 服务熔断

服务降级 -> 服务熔断 -> 链路恢复

Hystrix入门使用 服务熔断 服务降级 服务雪崩

断路器就是保险丝,熔断: 应对服务雪崩效应的链路保护机制,当检测节点微服务调用响应正常后,恢复调用链路

  • 熔点机制通过Hystrix实现
  • 监控微服务调用的状况:
    • 5秒20次调用失败,就会启动熔断机制。

熔断是> https://martinfowler.com/bliki/CircuitBreaker.html

2.1 熔断原理

  • 熔断打开: 请求不再进行调用当前服务

  • 熔断关闭: 熔断关闭,不再对服务进行熔断

  • 熔断半开: 部分请求根据规则调用当前服务,如果请求成功且符合规则,则关闭熔断

    设计断路器的三个重要参数; 快照时间窗口、请求总数阀值、错误百分比阀值

  • 快照时间窗口: 统计请求和错误数据,默认为10s内

  • 请求总数阀值: 在快照时间窗内,必须满足请求总数才有资格熔断,默认为20;

  • 错误百分比法制: 当请求总数在快照时间内超过阀值,例如在10s内发生30次调用,有15次失败,则断路器打开。

Hystrix入门使用 服务熔断 服务降级 服务雪崩

当熔断开启后,直接调用fallback;

2.2 案例

  1. 在 payment 业务当中,添加业务方法代码,以便于我们测试熔断机制。
  @HystrixCommand(fallbackMethod = "paymentCircuitBreakHandler",commandProperties = {
            //开启熔断;
            @HystrixProperty(name = "circuitBreaker.enabled",value = "true"),
            //请求次数至少10次
            @HystrixProperty(name = "circuitBreaker.requestVolumeThreshold",value = "10"),
            //在10s中
            @HystrixProperty(name = "circuitBreaker.sleepWindowInMilliseconds",value = "10000"),
            //错误率 60%
            @HystrixProperty(name = "circuitBreaker.errorThresholdPercentage",value = "20")
    })
    public String paymentCirumentBreak(Integer id) {
        if(id<0){
            throw new RuntimeException("不能为负数");
        }
        //
        String rid = UUID.randomUUID().toString().replace("-","");
        return "调用成功: 流水号为: "+rid;
    }
    public String paymentCircuitBreakHandler(Integer id){
        return "调用失败: === 降级处理"+id;
    }
  1. 在Controller当中调用Service,并打开浏览器进行测试;

    • 测试时候,传入负数参数连续调用n次,后在传入正数,会发现,正数返回的也是服务降级的内容,说明断路器Open;

    Hystrix入门使用 服务熔断 服务降级 服务雪崩

    • 再多次调用正数内容,熔断慢慢恢复到正常状态 closed;

    Hystrix入门使用 服务熔断 服务降级 服务雪崩

    上述熔断过程就是 closed -> open ->halfOpen -> closed 的过程

3. 服务监控

Hystrix还提供了一个准实时的调用监控,以报表的方式或者图形化的方式展现给用户。SpringCloud提供了hystrixDashboard的整合,对监控内容转为可视化界面。

案例

  1. 创建Module

Hystrix入门使用 服务熔断 服务降级 服务雪崩

  1. POM
   <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-hystrix-dashboard</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
  </dependency>
  1. yaml
Server.port=9001
  1. 主类激活。

Hystrix入门使用 服务熔断 服务降级 服务雪崩

  1. 修改被监控的微服务

注意只要涉及到监控,就必须要添加 actuator 依赖

再主类当中添加如下代码

Hystrix入门使用 服务熔断 服务降级 服务雪崩

  1. 访问localhost:9001/hystrix, 监控8001服务

在hystrix监控栏目中输入被监控的地址: localhost:8001/hystrix.stream

Hystrix入门使用 服务熔断 服务降级 服务雪崩

Hystrix入门使用 服务熔断 服务降级 服务雪崩文章来源地址https://www.toymoban.com/news/detail-470071.html

到了这里,关于Hystrix入门使用 服务熔断 服务降级 服务雪崩的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【微服务笔记10】微服务组件之Hystrix实现服务降级和服务熔断

    这篇文章,主要介绍微服务组件之Hystrix实现服务降级和服务熔断。 目录 一、服务降级 1.1、什么是服务降级 1.2、实现服务降级 (1)引入依赖 (2)编写Service层代码 (3)编写Controller层代码 (4)运行测试 (5)fallbackMethod属性 二、服务熔断 2.1、什么是服务熔断 2.2、实现服务

    2023年04月11日
    浏览(68)
  • 云原生微服务 Spring Cloud Hystrix 降级、熔断实战应用

    第一章 Java线程池技术应用 第二章 CountDownLatch和Semaphone的应用 第三章 Spring Cloud 简介 第四章 Spring Cloud Netflix 之 Eureka 第五章 Spring Cloud Netflix 之 Ribbon 第六章 Spring Cloud 之 OpenFeign 第七章 Spring Cloud 之 GateWay 第八章 Spring Cloud Netflix 之 Hystrix 多个微服务之间调用的时候,假如微服

    2024年02月08日
    浏览(31)
  • SpringCloud-Hystrix服务熔断与降级工作原理&源码 | 京东物流技术团队

    在微服务架构中,根据业务来拆分成一个个的服务,服务与服务之间可以相互调用(RPC),在Spring Cloud可以用RestTemplate+Ribbon和Feign来调用。为了保证其高可用,单个服务通常会集群部署。由于网络原因或者自身的原因,服务并不能保证100%可用,如果单个服务出现问题,调用这

    2024年02月14日
    浏览(30)
  • 微服务springcloud 06.feign框架,配合ribbon 负载均衡和重试,配合hystrix 降级,监控和熔断测试

    feign是ribbon +hystrix 的整合 01.新建 sp09-feign 项目 第一步: 第二步:选择依赖: pom.xml 需要添加 sp01-commons 依赖: 第三步:修改sp09-feign项目的application.yml 第四步:sp09-feign的主程序添加 @EnableDiscoveryClient 和 @EnableFeignClients 02.feign 声明式客户端 第一步:声明三个代理接口 这里的

    2024年02月10日
    浏览(40)
  • Dubbo hystrix 熔断降级 示例

    目录 Pom 应用启动类 接口 服务提供者 消费者 总结 因为jar包冲突问题报错 java.lang.NoSuchMethodError: org.springframework.boot.builder.SpringApplicationBuilder.([Ljava/lang/Object;)V 解决方式修改低版本springboot 改成如下 版本对照 全代码 pom 启动 实现 yml 有需要加上这个 有超时熔断跳转到 reliable

    2024年02月12日
    浏览(34)
  • Hystrix和Sentinel熔断降级设计理念

    Sentinel 和 Hystrix 的原则是一致的: 当检测到调用链路中某个资源出现不稳定的表现,例如请求响应时间长或异常比例升高的时候,则对这个资源的调用进行限制,让请求快速失败,避免影响到其它的资源而导致级联故障。 Sentinel 对这个问题采取了两种手段: 通过并发线程数进

    2024年02月09日
    浏览(33)
  • 服务熔断Hystrix入门

    在微服务架构中,一个请求需要调用多个服务是非常常见的。如客户端访问A服务,而A服务需要调用B服务,B服务需要调用C服务,由于网络原因或者自身的原因,如果B服务或者C服务不能及时响应,A服务将处于阻塞状态,直到B服务C服务响应。此时若有大量的请求涌入,容器的

    2024年02月03日
    浏览(30)
  • 【从0到1设计一个网关】基于Hystrix实现熔断降级

    上文我们已经成功实现了请求重试与请求限流,接下来我们开始实现熔断与服务降级。 熔断与服务降级,在SpringCloud中设计到的就是我们的hystrix,这里我们也将会考虑配合hystrix来实现熔断与服务降级。 如果不了解hystix的可以先进行一下了解。 由于这里我是用的是基于hystr

    2024年02月05日
    浏览(38)
  • 【OpenFeign】OpenFeign结合Hystrix和Sentinel实现熔断降级

    OpenFeign可以与Hystrix和Sentinel结合使用,实现降级和熔断。 使用OpenFeign需要引入OpenFeign的依赖: spring-cloud-starter-openfeign 引入的依赖如下: 默认已经自动引入了hystrix的依赖,不再需要单独再引入hystrix了。 降级方法的类需要实现FeignClient的接口,同时这个类需要注入到Spring容器

    2024年02月11日
    浏览(27)
  • 高版本Spring Cloud中OpenFeign整合Hystrix熔断降级不生效的问题及解决方案

    本文将介绍在使用高版本Spring Cloud(2020.0.x及以后),由于取消了Hystrix的集成,导致OpenFeign与Hystrix熔断降级不生效的问题。同时,也将给出解决该问题的方案,即添加feign.circuitbreaker.enabled=true配置。 随着Spring Cloud框架的发展,高版本Spring Cloud(2020.0.x及以上)中取消了对Hy

    2024年02月22日
    浏览(34)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包