spring cloud zuul 升级 gateway记录

一开始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 代码:


  
      io.reactivex
      rxjava
  

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记录)