博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
跟我学Spring Cloud(Finchley版)-18-Zuul深入
阅读量:6140 次
发布时间:2019-06-21

本文共 1952 字,大约阅读时间需要 6 分钟。

  hot3.png

本节探讨Zuul的高级特性。

TIPS:

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

过滤器详解

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

内置过滤器详解

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

详见:

为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的限流。

其他

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

本文首发

干货分享

全是干货哦!

转载于:https://my.oschina.net/eacdy/blog/3006922

你可能感兴趣的文章
Docker的技术不再局限于测试和开发
查看>>
技术干货:工欲善其事,必先利其器 阿里云数据库系列谈之一
查看>>
禁用ViewState
查看>>
深入理解Java HashMap实现原理
查看>>
阿里云备案获取服务号
查看>>
深入理解Python中的__builtin__和__builtins__
查看>>
YII AJAX registerScript
查看>>
ARC forbids explicit message send of 'retainCount'
查看>>
redis单机安装
查看>>
golang内存分配
查看>>
手把手教你----使用Nuget管理自己的项目库
查看>>
trubleshoting方式浅谈
查看>>
编目DB2数据库(原创)
查看>>
企业开发中选择logback而不是log4j的理由
查看>>
信息抽取的五个层次
查看>>
IOS开发--横向流水布局实现
查看>>
【DATAGUARD】手工恢复备库日志中断
查看>>
Kettle访问IDH2.3中的HBase
查看>>
jQuery网页背景灯光闪烁特效
查看>>
【转载】JVM类加载机制小结
查看>>