美文网首页
spring cloud zuul 升级 gateway记录

spring cloud zuul 升级 gateway记录

作者: hero_zh | 来源:发表于2018-11-27 12:14 被阅读0次

    一开始spring cloud 得版本如下:

    spring boot : 1.5.10.RELEASE 
    
    spring cloud : Edgware.SR3
    

    网关使用 netflix 得 zuul组件,但在使用之后发现,有以下缺点:

    1、zuul 1 由于底层使用 servlet 做为实现,在最大并发、性能上设置了瓶颈。
    
    2、无法转发WebSocket。
    
    3、无法在 zuul 开启 HTTPS转发服务到没开HTTPS得下游服务中。
    
    4、spring cloud 社区对最新开源得zuul 2 不会进行更新支持。
    

    鉴于上述问题,转而升级为 spring cloud gateway ,升级后spring cloud 版本为:

    spring boot : 2.0.6.RELEASE
    
    spring cloud : Finchley.SR2 
    

    spring boot 1.5x 升级为 2.x 得配置修改与spring cloud E 版本升级到 F 版本得项目名改变不再赘述,主要将 zuul 改为 sprign cloud gateway 得问题。

    1、maven 配置:

    在引入F版本得配置后,出现了类加载错误,经过调试,发现是 rxjava 的引入出现冲突,需要在以下两个引入中去掉:

            1、spring-cloud-starter-netflix-eureka-client
    
            2、spring-cloud-starter-netflix-hystrix
    

    排除 rxjava maven 代码:

    <exclusions>
      <exclusion>
          <groupId>io.reactivex</groupId>
          <artifactId>rxjava</artifactId>
      </exclusion>
    </exclusions>
    

    2、容器:

    在 gateway 中,目前只支持使用默认的 netty 作为启动容器,不支持其他的如tomcat、undertow,如加入其他容器,则会启动失败。

    3、cros:

    在官方文档中,只需要在application.yml 中配置 corsConfigurations ,就可以启动跨域配置,但实际上,这只注入了对应的配置,使用改配置的 CorsWebFilter 却没有被注入,需要手动创建并注入到spring 中,如下:

    @Configuration
    public class CorsConfig {
    
    
        @Autowired
        private GlobalCorsProperties globalCorsProperties;
    
    
        @Bean
        public CorsWebFilter corsWebFilter(){
            UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource(new PathPatternParser());
            globalCorsProperties.getCorsConfigurations().forEach(source::registerCorsConfiguration);
            return new CorsWebFilter(source);
        }
    }
    

    4、HTTPS

    在 gateway 中,如果 gateway 开启了 HTTPS,那么对下游服务的转发,默认就是HTTPS的,如果下游服务不想开启HTTPS,则需要去设置转发的URL,可参考该文章:spring-cloud-gateway使用https注意事项2---如何在转发后端服务的时候... - 简书 (PS:这个问题已被列入 2.1.0RC1 版本里程碑中)

    如果下游服务开启了HTTPS,则需要在 gateway 中设置证书,或者设置 httpclient.ssl.use-insecure-trust-manager: true 来忽略证书。

    在有多个服务,并且服务之间使用fegin来进行调用时,需要在 @FeignClient 注解的 name 属性上加入 HTTPS:// ,如果不加上,默认的时使用HTTP进行调用,在调用时会失败。

    5、 webSocket

    如果需要 gateway 进行转发 webSocket,在 gateway 开启了HTTPS的时候,下游服务必须也开启HTTPS,原因与上个问题相似,在转发webSocket的时候,默认是使用 wss 协议进行转发,如果强行转为 ws 的话,会建立 webSocket 连接失败。(同2.1.0版本RC1里程碑)

    在转发 webSocket的 route 中,如果加入了 Hystrix 的配置,会出现超时异常导致webSocket断开,具体可看:Use websocket to establish a connection, and 504 gateway time out appears when Hystrix is added · Issue #597 · spring-cloud/spring-cloud-gateway · GitHu
    (PS:Finchley.SR1 出现 ,Finchley.SR2 中没有出现)

    如果是使用stomp建立webSocket的话,在负载均衡中,必须要开启外部 Broker ,否则订阅在负载均衡中不会被传递。

    6、Swagger

    在zuul中,可使用Swagger本身的配置集成下游服务的swagger api,但在 gateway 中不行,需要手动集成,具体可看:Spring Cloud Gateway整合Swagger聚合微服务系统API文档(非Zuul) - 我的小地方 - CSDN博客

    在 Spring cloud Finchley.SR2 版本包含的 spring cloud gateway 2.0.2.RELEASE 中,该文章的 SwaggerHeaderFilter 已经被框架实现,无需再实现一次

    相关文章

      网友评论

          本文标题:spring cloud zuul 升级 gateway记录

          本文链接:https://www.haomeiwen.com/subject/kqkgqqtx.html