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

时光毁灭记忆、已成空白 提交于 2019-11-26 23:59:01

本节探讨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  */ @Component public 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的高可用

实战技巧

其他

虽然是基于Edgware写的,但Finchley版本依然适用。

本文首发

http://www.itmuch.com/spring-cloud/finchley-18/

干货分享

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!