继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

跟我学Spring Cloud(Finchley版)-18-Zuul深入

2019-03-18 12:34:072040浏览

大目

1实战 · 133手记
TA的实战

本节探讨Zuul的高级特性。

TIPS:

笔者已经写过很多Zuul相关的文章,对于已经写过的内容,就不再啰嗦一遍了,直接贴地址吧。

过滤器详解

过滤器是Zuul的核心,Zuul大多功能都是基于过滤器实现的。详见:Spring Cloud Zuul过滤器详解,文章着重探讨了Zuul过滤器的生命周期、如何自定义过滤器、如何禁用指定过滤器等。

内置过滤器详解

Zuul内置了很多过滤器,这些过滤器帮助我们实现各种能力,来分析一下内置过滤器有哪些,分别是干嘛的。

详见:Spring Cloud内置的Zuul过滤器详解

为Zuul提供回退

跟我学Spring Cloud(Finchley版)-16-Zuul 讲过,Zuul整合了Hystrix,而Hystrix提供fallback的能力。

前文已详细讲过通用方式提供fallback、Feign提供fallback。如果不记得如何提供Fallback,可前往如下文章复习。

/**
 * @author itmuch.com
 */@Componentpublic class MyFallbackProvider implements FallbackProvider {  @Override
  public String getRoute() {    // 表明是为哪个微服务提供回退,*表示为所有微服务提供回退
    return "*";
  }  @Override
  public ClientHttpResponse fallbackResponse(String route, Throwable cause) {    if (cause instanceof HystrixTimeoutException) {      return response(HttpStatus.GATEWAY_TIMEOUT);
    } else {      return this.fallbackResponse();
    }
  }  public ClientHttpResponse fallbackResponse() {    return this.response(HttpStatus.INTERNAL_SERVER_ERROR);
  }  private ClientHttpResponse response(final HttpStatus status) {    return new ClientHttpResponse() {      @Override
      public HttpStatus getStatusCode() throws IOException {        return status;
      }      @Override
      public int getRawStatusCode() throws IOException {        return status.value();
      }      @Override
      public String getStatusText() throws IOException {        return status.getReasonPhrase();
      }      @Override
      public void close() {
      }      @Override
      public InputStream getBody() throws IOException {        return new ByteArrayInputStream("服务不可用,请稍后再试。".getBytes());
      }      @Override
      public HttpHeaders getHeaders() {        // headers设定
        HttpHeaders headers = new HttpHeaders();
        MediaType mt = new MediaType("application", "json", Charset.forName("UTF-8"));
        headers.setContentType(mt);        return headers;
      }
    };
  }
}

这样,当Zuul后端服务发生异常时,就会进到该Fallback类,并返回服务不可用,请稍后再试。

高可用

详见:Zuul的高可用

实战技巧




打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP