zoukankan      html  css  js  c++  java
  • spring-cloud-starter-hystrix(断路器)服务不通或者调用失败后的错误处理和回调

    崩效应

    在微服务架构中通常会有多个服务层调用,大量的微服务通过网络进行通信,从而支撑起整个系统。各个微服务之间也难免存在大量的依赖关系。然而任何服务都不是100%可用的,网络往往也是脆弱的,所以难免有些请求会失败。基础服务的故障导致级联故障,进而造成了整个系统的不可用,这种现象被称为服务雪崩效应。服务雪崩效应描述的是一种因服务提供者的不可用导致服务消费者的不可用,并将不可用逐渐放大的过程。

    Netflix Hystrix断路器

    Netflix的Hystrix类库实现了断路器模式,在微服务架构中有多个层的服务调用。一个低水平的服务群中一个服务挂掉会给用户导致级联失效。调用一个特定的服务达到一定阈值(在Hystrix里默认是5秒内20个失败),断路由开启并且调用没有成功的。开发人员能够提供错误原因和开启一个断路由回调。

    断路器简介

    Netflix has created a library called Hystrix that implements the circuit breaker pattern. In a microservice architecture it is common to have multiple layers of service calls.

    —-摘自官网

    Netflix已经创建了一个名为Hystrix的库来实现断路器模式。 在微服务架构中,多层服务调用是非常常见的。

    较底层的服务如果出现故障,会导致连锁故障。当对特定的服务的调用达到一个阀值(hystric 是5秒20次) 断路器将会被打开。

    断路打开后,可用避免连锁故障,fallback方法可以直接返回一个固定值。

    使用Hystrix

    第一步:

    POM添加依赖

            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-hystrix</artifactId>
            </dependency>

    Application入口main方法上增加@EnableCircuitBreaker注解

    第二步:

    基于RestTemplate的调用方式集成:

    在方法上加上@HystrixCommand,并指定fallbackMethod方法。

    复制代码
    @Service
    public class HelloService {
    
        @Autowired
        RestTemplate restTemplate;
    
        @HystrixCommand(fallbackMethod = "hiError")
        public String hiService(String name) {
            return restTemplate.getForObject("http://SERVICE-HI/hi?name="+name,String.class);
        }
    
        public String hiError(String name) {
            return "hi,"+name+",sorry,error!";
        }
    }
    复制代码

    基于Feign的方式:

    在SchedualServiceHi接口的注解中加上fallback的指定类就行了:

    @FeignClient(value = "service-hi",fallback = SchedualServiceHiHystric.class)
    public interface SchedualServiceHi {
        @RequestMapping(value = "/hi",method = RequestMethod.GET)
        String sayHiFromClientOne(@RequestParam(value = "name") String name);
    }

    SchedualServiceHiHystric类:

    复制代码
    @Component
    public class SchedualServiceHiHystric implements SchedualServiceHi {
        @Override
        public String sayHiFromClientOne(String name) {
            return "sorry "+name;
        }
    }
    复制代码

    果使用feign不想用断路器的话,可以在配置文件中关闭它,配置如下:

    feign.hystrix.enabled=false

    第三步:

    一些通用配置:

    参考官网:https://github.com/Netflix/Hystrix/wiki/Configuration

    Maven示例:

    https://github.com/easonjim/spring-cloud-demo/tree/master/ZooKeeper

    参考:

    https://zhuanlan.zhihu.com/p/26426835(以上内容部分内容转自此篇文章)

    http://blog.csdn.net/w_x_z_/article/details/53444199(以上内容部分内容转自此篇文章)

    https://www.cnblogs.com/EasonJim/p/7613595.html

  • 相关阅读:
    (转)在SQL Server 2016,Visual Studio 2017环境下,连接数据库屡屡失败,在connectionString上出的问题
    WPF中,DataGrid最左边多出一行的解决方案
    (转)SQL注入攻击简介
    Bot Framework:Activity类简明指南
    微软Bot Framework文档中,关于Sign-in Card的一处代码错误及更正
    微软分布式机器学习工具包DMTK——初窥门径
    在2017年,如何将你的小米4刷上Windows 10 mobile?(后附大量图赏)
    第十周总结
    产品介绍 宿舍小助手
    博客园 之 “水王”
  • 原文地址:https://www.cnblogs.com/smallfa/p/13237465.html
Copyright © 2011-2022 走看看