博客
关于我
SpringCloud了解(五)(Feign 断路器)
阅读量:152 次
发布时间:2019-02-28

本文共 1323 字,大约阅读时间需要 4 分钟。

Feign断路器是为了将不能执行的服务进行一个回调,避免大量的请求没有处理导致阻塞。

以下是引用别人的讲解:

(地址:https://www.jianshu.com/p/ba6adfd7bac1)

为什么要实现断路器模式?

在微服务架构中,根据业务来拆分成一个个的服务,服务与服务之间可以相互调用(RPC),在Spring Cloud可以用RestTemplate+Ribbon或Feign来调用。为了保证其高可用,单个服务通常会集群部署。由于网络原因或者自身的原因,服务并不能保证100%可用,如果单个服务出现问题,调用这个服务就会出现线程阻塞,此时若有大量的请求涌入,Servlet容器的线程资源会被消耗完毕,导致服务瘫痪。服务与服务之间的依赖性,故障会传播,会对整个微服务系统造成灾难性的严重后果,这就是服务故障的“雪崩”效应。

为了解决这个问题,业界提出了断路器模型。

断路器模式的简单原理:

在微服务架构中,一个请求需要调用多个服务是非常常见的,较底层的服务如果出现故障,会导致连锁故障。当对特定的服务的调用的不可用达到一个阀值(Hystric 是5秒20次)断路器将会被打开。断路打开后,可用避免连锁故障,fallback方法可以直接返回一个固定值。

目录


1.配置文件开启断路器

修改application.yml,添加hystrix

feign:  hystrix:    enabled: true

这个是打开了断路器,默认一般是关闭的

2.回调制定的类

1.在接口中的FeignClient注解中添加一个fallback回调的类

比如这样,在以前的HelloService的接口中去修改

@FeignClient(value = "guoergouProducer",fallback = HelloSerivceImpl.class) //回调自身的继承的类public interface HelloService {    @RequestMapping("/hello")    public String ServiceHello(@RequestParam("name")String name);}

2.创建回调的类,去实现接口

比如我去创建HelloServiceImpl类去实现HelloService接口,然后去创建回调的方法

@Componentpublic class HelloSerivceImpl implements HelloService{    @Override    public String ServiceHello(String name) {        return "Sorry "+name+" The Service not Found";    }}

这个时候如果消费端去注册中心注册后去查找服务提供者,如果没有找到就会回调这个HelloSeImpl中的方法。

3.启动访问服务

1.启动注册中心

2.启动服务提供者

3.启动修改后有断路器的Feign客户端

4.可以通过Feign去访问服务

5.将服务提供者关闭

这个时候再去访问这个服务就会回调找不到服务的方法

转载地址:http://evpc.baihongyu.com/

你可能感兴趣的文章
NLP 基于kashgari和BERT实现中文命名实体识别(NER)
查看>>
NLP 时事和见解【2023】
查看>>
NLP 模型中的偏差和公平性检测
查看>>
Vue3.0 性能提升主要是通过哪几方面体现的?
查看>>
NLP 项目:维基百科文章爬虫和分类【01】 - 语料库阅读器
查看>>
NLP_什么是统计语言模型_条件概率的链式法则_n元统计语言模型_马尔科夫链_数据稀疏(出现了词库中没有的词)_统计语言模型的平滑策略---人工智能工作笔记0035
查看>>
NLP、CV 很难入门?IBM 数据科学家带你梳理
查看>>
NLP三大特征抽取器:CNN、RNN与Transformer全面解析
查看>>
NLP入门(六)pyltp的介绍与使用
查看>>
NLP学习笔记:使用 Python 进行NLTK
查看>>
NLP度量指标BELU真的完美么?
查看>>
NLP的不同研究领域和最新发展的概述
查看>>
NLP的神经网络训练的新模式
查看>>
NLP采用Bert进行简单文本情感分类
查看>>
NLP问答系统:使用 Deepset SQUAD 和 SQuAD v2 度量评估
查看>>
NLP项目:维基百科文章爬虫和分类【02】 - 语料库转换管道
查看>>
NLP:从头开始的文本矢量化方法
查看>>
NLP:使用 SciKit Learn 的文本矢量化方法
查看>>
NLTK - 停用词下载
查看>>
nmap 使用总结
查看>>