Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Spring Cloud Gateway 网关尝鲜

Spring Cloud Gateway 网关尝鲜

作者头像
猿天地
发布于 2018-07-25 09:32:31
发布于 2018-07-25 09:32:31
1.3K00
代码可运行
举报
文章被收录于专栏:猿天地猿天地
运行总次数:0
代码可运行

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需要的依赖信息:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.0.1.RELEASE</version>
</parent>

<dependencyManagement>
    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-dependencies</artifactId>
            <version>Finchley.RELEASE</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
    </dependencies>
</dependencyManagement>

<dependencies>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-gateway</artifactId>
    </dependency>
</dependencies>

编写启动类:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
/**
 * 网关启动入口
 * 
 * @author yinjihuan
 * 
 * @about http://cxytiandi.com/about
 *
 */
@SpringBootApplication
public class GatewayApplication {
    public static void main(String[] args) {
        SpringApplication.run(GatewayApplication.class, args);
    }
}

简单路由示列

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

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
server:
  port: 8084
spring:
  cloud:
    gateway:
      routes:
      - id: path_route
        uri: http://cxytiandi.com
        predicates:
        - Path=/course

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

课程列表

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

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

application.properties

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
spring.cloud.gateway.enabled=false.

application.yml

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
spring:
  cloud:
    gateway:
      enabled: false

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
@Bean
public RouteLocator customRouteLocator(RouteLocatorBuilder builder) {
       return builder.routes()
              .route(r -> r.path("/course").uri("http://cxytiandi.com"))
              .build();
}

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

猿天地

文章推荐

1

大牛坐镇|高端JAVA纯技术群你要加入吗?

2

Spring Cloud如何提供API给客户端

3

前后端API交互如何保证数据安全性?

4

Zuul过滤器获取请求参数问题?

5

Java做爬虫也很牛

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2018-06-26,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 猿天地 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
【欣赏中华武术】SpringCloud 2.x之网关Spring Cloud Gateway
Spring Cloud Gateway是由spring官方基于Spring5.0、Spring Boot2.x、Project Reactor等技术开发的网关,目的是代替原先版本中的Spring Cloud Netfilx Zuul,目前Netfilx已经开源了Zuul2.0,但Spring 没有考虑集成,而是推出了自己开发的Spring Cloud GateWay。该项目提供了一个构建在Spring Ecosystem之上的API网关,旨在提供一种简单而有效的途径来发送API,并向他们提供交叉关注点,例如:安全性,监控、埋点,限流等。(具体可以查看官网http://spring.io/projects/spring-cloud-gateway)
BUG弄潮儿
2022/06/30
2690
【欣赏中华武术】SpringCloud 2.x之网关Spring Cloud Gateway
Spring Cloud Gateway基于内置过滤工厂实现限流
本文使用 gateway 内置的过滤工厂 -RequestRateLimiter 实现限流的。
胖虎
2019/06/26
1.2K0
Spring Cloud Gateway基于内置过滤工厂实现限流
Spring Cloud 之 Gateway.
Zuul 基于servlet 2.5 (works with 3.x),使用阻塞API。它不支持任何长期的连接,如websocket。
JMCui
2019/07/29
1.4K0
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 链的方式提供了网关基本的功能, 例如: 安全, 监控/埋点, 和限流等
芥末鱿鱼
2020/09/22
1.3K0
Spring Cloud 之服务网关 Gateway (一)
每天20分钟之spring-cloud-gateway基础一
基于springboot和spring webflux,基于netty运行,的http网关服务。
李子健
2022/08/16
4760
基于Redis做Spring Cloud Gateway 中的速率限制实践-spring cloud 入门教程
目前Spring Cloud Gateway是仅次于 Spring Cloud Netflix 的第二大最受欢迎的 Spring Cloud 项目(就 GitHub 上的 Star 数而言)。它是作为 Spring Cloud 家族中 Zuul 代理的继任者而创建的。该项目为微服务架构提供了一个 API 网关,并建立在反应式Netty和 Project Reactor之上。它旨在提供一种简单但有效的方法来路由到 API 并解决诸如安全性、监控/指标和弹性等常见问题。 Spring Cloud Gateway 为您提供了许多功能和配置选项。今天我将专注于网关配置的一个但非常有趣的方面——速率限制。速率限制器可以定义为一种控制网络上发送或接收流量速率的方法。我们还可以定义几种类型的速率限制。Spring Cloud Gateway 目前提供了一个Request Rate Limiter,它负责将每个用户限制为每秒 N 个请求。与 Spring Cloud Gateway 一起 使用时RequestRateLimiter,我们可能会利用 Redis。Spring Cloud 实现使用令牌桶算法做限速。这个算法有一个集中的存储桶主机,你可以在每个请求上获取令牌,然后慢慢地将更多的令牌滴入桶中。如果桶为空,则拒绝请求。
jack.yang
2025/04/05
960
基于Redis做Spring Cloud Gateway 中的速率限制实践-spring cloud 入门教程
Spring Cloud Gateway 网关
https://docs.spring.io/spring-cloud-gateway/docs/current/reference/html/#gateway-request-predicates-factories
不惑
2023/12/29
2660
Spring Cloud Gateway 网关
Spring Cloud Gateway微服务网关
网关为微服务架构的系统提供简单、有效且统一的API路由管理,作为系统的统一入口,提供内部服务的路由中转,给客户端提供统一的服务,可以实现一些和业务没有耦合的公用逻辑,主要功能包含认证、鉴权、路由转发、安全策略、防刷、流量控制、监控日志等。
张云飞Vir
2022/10/28
5480
【spring cloud】 网关Zuul(过滤:安全、监控、限流、路由)
1. 添加依赖 创建项目tcloud-gateway-zuulserver , pom.xml内容如下
用户5640963
2019/07/26
1K0
极速体验SpringCloud Gateway
Spring Cloud Gateway是Spring Cloud技术栈中的网关服务,本文实战构建一个SpringCloud环境,并开发一个SpringCloud Gateway应用,快速体验网关服务;
程序员欣宸
2019/07/11
8510
极速体验SpringCloud Gateway
SpringCloud 2020版本教程2:使用spring cloud gateway作为服务网关
Spring Cloud Gateway是Spring Cloud官方推出的第二代网关框架,取代Zuul网关。网关作为流量的,在微服务系统中有着非常作用,网关常见的功能有路由转发、权限校验、限流控制等作用。
方志朋
2022/01/06
4410
SpringCloud 2020版本教程2:使用spring cloud gateway作为服务网关
Spring Cloud 终于按捺不住推出了自己的服务网关 Gateway
Spring 官方最终还是按捺不住推出了自己的网关组件:Spring Cloud Gateway ,相比之前我们使用的 Zuul(1.x) 它有哪些优势呢?Zuul(1.x) 基于 Servlet,使用阻塞 API,它不支持任何长连接,如 WebSockets,Spring Cloud Gateway 使用非阻塞 API,支持 WebSockets,支持限流等新特性
纯洁的微笑
2018/12/28
7080
Spring Cloud 终于按捺不住推出了自己的服务网关 Gateway
Spring Cloud Gateway 入门
Spring Cloud Gateway ,相比之前我们使用的 Zuul(1.x) 它有哪些优势呢?Zuul(1.x) 基于 Servlet,使用阻塞 API,它不支持任何长连接,如 WebSockets。Spring Cloud Gateway 使用非阻塞 API,支持 WebSockets,支持限流等新特性。本文首先用官方的案例带领大家来体验下Spring Cloud的一些简单的功能。
程序员果果
2019/05/21
9490
SpringCloudGateway笔记(1)-介绍与基础使用
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
yingzi_code
2019/08/30
4500
Spring Cloud Gateway初体验
这篇文章讲述了如何简单地使用Spring Cloud Gateway,来源于Spring Cloud官方案例,地址https://spring.io/guides/gs/gateway 。
方志朋
2022/05/08
3420
Spring Cloud Gateway快速体验
GlobalFilter只要注册到Spring容器,就可以应用在所有请求,比如监控请求耗时
十毛
2019/03/27
1.1K0
Spring Cloud 之服务网关 Gateway(二) 集成 Swagger 组件
Spring Cloud 之服务网关 Gateway(二) 集成 Swagger 组件
芥末鱿鱼
2020/09/22
2K0
Spring Cloud 之服务网关 Gateway(二) 集成 Swagger 组件
SpringCloud 2.x学习笔记:12、Spring Cloud Gateway简单例子(Greenwich版本)
Spring Cloud Gateway是Spring Cloud官方推出的第二代网关框架,取代Zuul网关。 Spring Cloud Gateway构建于Spring生态系统之上,包括Spring5,SpringBoot2等。它的目标是提供简单、有效的方式路由的API
程裕强
2019/07/02
1.2K0
SpringCloud 2.x学习笔记:12、Spring Cloud Gateway简单例子(Greenwich版本)
Spring Cloud Gateway整合nacos实战(三)
Spring Cloud GateWay是Spring Cloud的⼀个全新项⽬,⽬标是取代Netflix Zuul,它基于Spring5.0+SpringBoot2.0+WebFlux(基于⾼性能的Reactor模式响应式通信框架Netty,异步⾮阻塞模型)等技术开发,性能⾼于Zuul,官⽅测试,GateWay是Zuul的1.6倍,旨在为微服务架构提供⼀种简单有效的统⼀的API路由管理⽅式。
Java技术债务
2022/08/09
2.4K0
Spring Cloud Gateway整合nacos实战(三)
springcloud笔记(三) API 网关 Zuul,Spring Cloud Config
它就像一个安检站 一样,所有外部的请求都需要经过它的调度与过滤,然后 API 网关来实现请 求路由、负载均衡、权限验证等功能;
一写代码就开心
2022/05/09
3760
springcloud笔记(三) API 网关 Zuul,Spring Cloud Config
相关推荐
【欣赏中华武术】SpringCloud 2.x之网关Spring Cloud Gateway
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档