一开始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 已经被框架实现,无需再实现一次
网友评论