服务容错

最近更新时间: 2024-10-17 17:10:00

操作场景

TSF 摒弃了已经不再继续维护的 Hystrix 作为容错模块,在原有单一的 fallback 上新增了 failfast、failover 和 forking。请配合 TSF 其他功能一起使用。

前提条件

开始实践服务容错功能前,请确保已完成了 【SDK 下载】 ,同时请确保 SDK 版本高于1.19

操作步骤

注意:

步骤1和步骤2与其他模块一样,已经使用过其他模块的可直接跳至步骤3。

1. 向工程中添加依赖。pom.xml 中添加以下代码:

<dependency>
    <groupId>com.tencent.tsf</groupId>
    <artifactId>spring-cloud-tsf-starter</artifactId>
    <version><!-- 调整为 SDK 最新版本号 --></version> 
</dependency>

2. 向 Application 类中添加注解 @EnableTsf

// 下面省略了无关的代码
@SpringBootApplication
@EnableTsf
public class ProviderApplication {
    public static void main(String[] args) {
        SpringApplication.run(ProviderApplication.class, args);
    }
}

3. 使用 Feign 上的 fallback 以及 fallbackFactory 功能。 TSF 容错兼容 feign 的容错功能,如果需要使用 feign 的如下降级功能,则需要关闭 Hystrix 开关。

@FeignClient(name = "circuit-breaker-mock-service", fallbackFactory = HystrixClientFallbackFactory.class)
@FeignClient(name = "circuit-breaker-mock-service", fallback = FeignClientFallback.class)

关闭 Hystrix 开关(默认是关闭的,如果之前使用了该功能,可以删除该配置或者关闭):

feign:
  hystrix:
    enabled: false

打开 TSF 开关:

feign:
  tsf:
    enabled: true

4. 在代码中使用容错功能。

// 下面省略了无关的代码
@TsfFaultTolerance(strategy = TsfFaultToleranceStragety.FAIL_OVER, parallelism = 2, fallbackMethod = "doWorkFallback")
public void doWork() throws InterruptedException {
    String response = providerDemoService.echo("1234");
    LOG.info("consumer-demo auto test, response: [" + response + "]");
}
public void doWorkFallback() {
    System.out.println("fallback");
}
// fallbackMethod可以加也可以不加,用户可以自行选择
@TsfFaultTolerance(strategy = TsfFaultToleranceStragety.FAIL_FAST)
public void doWork2() throws InterruptedException {
    String response = providerDemoService.echo2("1234");
    LOG.info("consumer-demo auto test, response: [" + response + "]");
}

可以看到,TSF 的容错使用起来非常方便,您只需在需要保护的方法上增加一个注解即可(需要该 Bean 被 Spring 所管理)。

容错策略说明

failfast、failover 和 forking 容错策略是可选择的配置:

容错策略 含义 支持配置
failfast 直接失败,对于没有幂等性的下游服务推荐 failfast
failover 请求错了之后会重试 重试次数 maxAttempts
forking 同时发送多个请求,需要用户配置并行度,例如同时发出两个请求,哪个先返回,就把这个结果返回回去。如果第一个请求是异常,则会等另一个请求,如果全部都异常,则返回异常。 并行度 parallelism

三种容错策略均支持 fallback 方法,要求入参类型和返回值类型与原方法相同。您可以选择是否添加某一策略

除了如上所述的基本功能外,TSF 还提供了选择容错异常的能力:

// 下面省略了无关的代码
@TsfFaultTolerance(strategy = TsfFaultToleranceStragety.FAIL_OVER, parallelism = 2, ignoreExceptions = {FeignException.class}, raisedExceptions = {RuntimeException.class, InterruptedException.class}, fallbackMethod = "doWorkFallback")
public void doWork() throws InterruptedException {
    String response = providerDemoService.echo("1234");
    LOG.info("consumer-demo auto test, response: [" + response + "]");
}

public void doWorkFallback() {
    System.out.println("fallback");
}
  • 用户如果设置了 ignoreExceptions,且当前异常是其中一个的子类的话,则不执行容错逻辑。

  • 如果用户没有设置 ignoreExceptions,或当前异常不是 ignoreExceptions 的子类且满足如下条件则执行容错逻辑:

  • 用户未设置 raisedExceptions,则执行容错逻辑。

  • 用户设定了 raisedExceptions,且当前异常为用户设置的 raisedExceptions 其中一个的子类,则执行容错逻辑。