前言
ps:整个系列文章,读者可以看加粗字词就好。
在上一篇 12.服务间的负载均衡 一文中,我们采用了Feign来实现远程调用,且结合Ribbon对请求进行了负载均衡。
但这一切基础,要求服务是正常运行的,那如果其中的一方 服务不能正常运行时,会出现什么状况呢?我们又该 如何解决 呢?接下来,就让我们一起进入今天的学习中。(嫌啰嗦可以直接跳到标题三。)
一、Feign、Ribbon和Hystrix关系
微服务在相互调用的过程中,会将请求做负载均衡,其次,为了防止某个微服务的故障,从而导致整个系统瘫痪(不可用),在实施微服务远程调用的过程中,我们通常会要求在调用方建立针对被调用方的 熔断机制,来防范 服务雪崩。
而要实现这个机制,在使用Feign情景下,我们可以通过Hystrix组件来快速实现。
还记得在上一篇中,我们提出 Feign = RestTemplate+Ribbon+Hystrix
的观点,它指的是,在Feign底层,已经集成了这三个功能,通过简单的配置,就可使用。<