Spring Cloud Gateway 网关尝鲜

Spring Cloud Gateway是Spring官方基于Spring 5.0,Spring Boot 2.0和Project Reactor等技术开发的网关,Spring Cloud Gateway旨在为微服务架构提供一种简单而有效的统一的API路由管理方式。Spring Cloud Gateway作为Spring Cloud生态系中的网关,目标是替代Netflix ZUUL,其不仅提供统一的路由方式,并且基于Filter链的方式提供了网关基本的功能,例如:安全,监控/埋点,和限流等。

可能有同学就要问了,不是已经有Zuul了吗,为什么又搞了一个网关,这更新的节奏确实很快哈,没精力还真学习不过来。

之所以新搞了一个网关,是因为Zuul基于servlet 2.5 (works with 3.x),使用阻塞API。它不支持任何长期的连接,如websocket。

Gateway建立在Spring Framework 5,Project Reactor和Spring Boot 2上,使用非阻塞API。支持Websockets,因为它与Spring紧密集成,所以它会是一个让开发者有更好体验的框架。当然性能的提升是肯定的,不然完全没必要重新搞一个啊,只不过Zuul2出来的太迟了,自己已经搞了一个,所以不太可能会将Zuul2集成到Spring Cloud中了。

关于性能这块的比较可以参考我周兄的文章《纠错帖:Zuul & Spring Cloud Gateway & Linkerd性能对比》

工作原理

工作原理

如上图所示,客户端发送请求到Spring Cloud Gateway,Gateway Handler Mapping确定请求与路由匹配,则会将请求交给Gateway Web Handler处理。
在代理前后可以执行多个过滤器。最后代理到具体的服务。

创建项目集成Gateway

首先还是最基本的步骤,创建一个Maven项目,添加Gateway需要的依赖信息:

 
  1. <parent>
  2. <groupId>org.springframework.boot</groupId>
  3. <artifactId>spring-boot-starter-parent</artifactId>
  4. <version>2.0.1.RELEASE</version>
  5. </parent>
  6.  
  7. <dependencyManagement>
  8. <dependencies>
  9. <dependency>
  10. <groupId>org.springframework.cloud</groupId>
  11. <artifactId>spring-cloud-dependencies</artifactId>
  12. <version>Finchley.RELEASE</version>
  13. <type>pom</type>
  14. <scope>import</scope>
  15. </dependency>
  16. </dependencies>
  17. </dependencyManagement>
  18.  
  19. <dependencies>
  20. <dependency>
  21. <groupId>org.springframework.cloud</groupId>
  22. <artifactId>spring-cloud-starter-gateway</artifactId>
  23. </dependency>
  24. </dependencies>

编写启动类:

 
  1. import org.springframework.boot.SpringApplication;
  2. import org.springframework.boot.autoconfigure.SpringBootApplication;
  3. /**
  4. * 网关启动入口
  5. *
  6. * @author yinjihuan
  7. *
  8. * @about http://cxytiandi.com/about
  9. *
  10. */
  11. @SpringBootApplication
  12. public class GatewayApplication {
  13. public static void main(String[] args) {
  14. SpringApplication.run(GatewayApplication.class, args);
  15. }
  16. }

简单路由示列

下面来实现一个最简单的转发功能,基于Path的匹配转发功能。

在resources下面建一个application.yml的文件, 内容如下:

 
  1. server:
  2. port: 8084
  3. spring:
  4. cloud:
  5. gateway:
  6. routes:
  7. - id: path_route
  8. uri: http://cxytiandi.com
  9. predicates:
  10. - Path=/course

当你访问http://localhost:8084/course的时候就会转发到http://cxytiandi.com/course,效果如下:
课程列表

关于路由规则什么的我们后面再做介绍,本章只是先体验下Spring Cloud Gateway的功能,能够创建一个新的项目,成功启动就可以了,一步步来。

如果你的项目中包含了spring-cloud-starter-gateway,但你不想启动网关的时候可以通过下面的配置禁用掉:

application.properties

 
  1. spring.cloud.gateway.enabled=false.

application.yml

 
  1. spring:
  2. cloud:
  3. gateway:
  4. enabled: false

上面讲解的是基于配置的方式来实现路由,还有一种方式是通过代码的方式来进行路由,比如:

 
  1. @Bean
  2. public RouteLocator customRouteLocator(RouteLocatorBuilder builder) {
  3. return builder.routes()
  4. .route(r -> r.path("/course").uri("http://cxytiandi.com"))
  5. .build();
  6. }

示列代码:https://github.com/yinjihuan/spring-cloud/tree/master/fangjia-gateway

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值