微服务解决方案 -- Spring Cloud Alibaba (四)服务熔断

不了解此套教程的可以移步之前章节
1.微服务解决方案 – Spring Cloud Alibaba (一)服务的注册与发现
2.微服务解决方案 – Spring Cloud Alibaba (二)服务提供者
3.微服务解决方案 – Spring Cloud Alibaba (三)服务消费者(Feign)

服务熔断


Spring Cloud Netfilx 的解决方案是Hystrix。阿里巴巴开源了Sentinel组件,实现了熔断器模式,Spring Cloud对这一组件进行了整合。在微服务架构中,一个请求需要调用多个服务是非常常见的。Sentinel 以流量为切入点,从流量控制、熔断降级、系统负载保护等多个维度保护服务的稳定性。

使用


我们在消费者项目中添加依赖

<dependency>
    <groupId>org.springframework.cloudgroupId>
    <artifactId>spring-cloud-starter-alibaba-sentinelartifactId>
dependency>

配置默认是关闭的。需要打开它

feign:
  sentinel:
    enabled: true

Hystrix一样配置fallback

@FeignClient(value = "nacos-provider",fallback = NacosServiceFallback.class)
public interface NacosProviderService {

    @GetMapping(value = "/hello/{message}" )
    String hello(@PathVariable(value = "message") String message);

}

NacosServiceFallback.java 一定要加上@Component注解

@Component
public class NacosServiceFallback implements NacosProviderService {

    @Override
    public String hello(String message) {
        return "sry ! fallback";
    }
}

关闭服务提供者,请求消费者会直接打印 sry! fallback
微服务解决方案 -- Spring Cloud Alibaba (四)服务熔断_第1张图片

你可能感兴趣的:(微服务解决方案)