SpringCloud-4.服务网关(GateWay)
目录
一、基本概念
1.1 什么是GateWay
1.2 GateWay的特性
1.3 GateWay 与 Zuul 的区别
二、三大核心概念与工作流程
2.1 三大核心概念
2.1.1 Route(路由)
2.1.2 Predicate(断言)
2.1.3 Filter(过滤)
2.2 工作流程
三、使用
3.1 基本配置
3.2 通过微服务名进行动态路由
3.3 Predict的使用
3.4 Filter的使用
3.5 自定义过滤器
一、基本概念
1.1 什么是GateWay
SpringCloud Gateway 是 Spring Cloud 的一个全新项目,基于 Spring 5.0+Spring Boot 2.0 和 Project Reactor 等技术开发的网关,它旨在为微服务架构提供一种简单有效的统一的 API 路由管理方式。
SpringCloud Gateway 作为 Spring Cloud 生态系统中的网关,目标是替代 Zuul,在Spring Cloud 2.0以上版本中,没有对新版本的Zuul 2.0以上最新高性能版本进行集成,仍然还是使用的Zuul 1.x非Reactor模式的老版本。而为了提升网关的性能,SpringCloud Gateway是基于WebFlux框架实现的,而WebFlux框架底层则使用了高性能的Reactor模式通信框架Netty。
Spring Cloud Gateway的目标提供统一的路由方式且基于 Filter 链的方式提供了网关基本的功能,例如:安全,监控/指标,和限流。
在Servlet3.1之后有了异步非阻塞的支持。Spring WebFlux 是 Spring 5.0 引入的新的响应式框架,区别于 SpringMVC,它不需要依赖Servlet API,它是完全异步非阻塞的,并且基于 Reactor 的相关API来实现响应式流规范。
功能:反向代理、鉴权、流量控制、熔断、日志监控......
1.2 GateWay的特性
1.基于Spring Framework 5, Project Reactor 和 Spring Boot 2.0 进行构建;
2.动态路由:能够匹配任何请求属性;
3.可以对路由指定 Predicate(断言)和 Filter(过滤器);
4.集成Hystrix的断路器功能;
5.集成 Spring Cloud 服务发现功能;
6.易于编写的 Predicate(断言)和 Filter(过滤器);
7.请求限流功能;
8.支持路径重写。
1.3 GateWay 与 Zuul 的区别
1、Zuul 1.x,是一个基于阻塞 I/ O 的 API Gateway ,采用的是Tomcat容器,使用的是传统的Servlet IO处理模型。
采用servlet模型的缺点:
servlet是一个简单的网络IO模型,当请求进入servlet container时,servlet container就会为其绑定一个线程,在并发不高的场景下这种模型是适用的。但是一旦高并发,线程数量就会上涨,而线程资源代价是昂贵的(上线文切换,内存消耗大)严重影响请求的处理时间。在一些简单业务场景下,不希望为每个request分配一个线程,只需要1个或几个线程就能应对极大并发的请求,这种业务场景下servlet模型没有优势。所以Zuul 1.X是基于servlet之上的一个阻塞式处理模型,即spring实现了处理所有request请求的一个servlet(DispatcherServlet)并由该servlet阻塞式处理。
2、Zuul 1.x 基于Servlet 2. 5使用阻塞架构,它不支持任何长连接(如 WebSocket)。 Zuul 的设计模式和Nginx较像,每次 I/ O 操作都是从工作线程中选择一个执行,请求线程被阻塞到工作线程完成,但是差别是Nginx 用C++ 实现,Zuul 用 Java 实现,而 JVM 本身会有第一次加载较慢的情况,使得Zuul 的性能相对较差。
3、Zuul 2.x理念更先进,想基于Netty非阻塞和支持长连接,但SpringCloud目前还没有整合。 Zuul 2.x的性能较 Zuul 1.x 有较大提升。在性能方面,根据官方提供的基准测试, Spring Cloud Gateway 的 RPS(每秒请求数)是Zuul 的 1. 6 倍。
4、Spring Cloud Gateway 建立 在 Spring Framework 5、 Project Reactor 和 Spring Boot 2 之上, 使用非阻塞 API。
5、Spring Cloud Gateway 还支持 WebSocket, 并且与Spring紧密集成拥有更好的开发体验
二、三大核心概念与工作流程
2.1 三大核心概念
一句话来说:web请求通过一些匹配条件,定位到真正的服务节点。并在这个转发过程的前后进行一些精细化控制。
2.1.1 Route(路由)
路由是构建网关的基本模块,它由ID,目标URI,一系列的断言和过滤器组成,如果断言为true则匹配该路由.
2.1.2 Predicate(断言)
开发人员可以匹配HTTP请求中的所有内容(例如请求头或请求参数),如果请求与断言相匹配则进行路由。(其实就是我们的匹配条件)
2.1.3 Filter(过滤)
指的是Spring框架中GatewayFilter的实例,使用过滤器可以在请求被路由前或者之后对请求进行修改。
2.2 工作流程
核心逻辑:路由转发+执行过滤器链
客户端向 Spring Cloud Gateway 发出请求。然后在 Gateway Handler Mapping 中找到与请求相匹配的路由,将其发送到 Gateway Web Handler。
Handler 再通过指定的过滤器链来将请求发送到我们实际的服务执行业务逻辑,然后返回。
过滤器之间用虚线分开是因为过滤器可能会在发送代理请求之前(“pre”)或之后(“post”)执行业务逻辑。
Filter在“pre”类型的过滤器可以做参数校验、权限校验、流量监控、日志输出、协议转换等,在“post”类型的过滤器中可以做响应内容、响应头的修改,日志的输出,流量监控等有着非常重要的作用。
三、使用
3.1 基本配置
1. 建Module-cloud-gateway-gateway9527
2.POM
<dependencies><!--gateway--><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-gateway</artifactId></dependency><!--eureka-client--><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-client</artifactId></dependency><!-- 引入自己定义的api通用包,可以使用Payment支付Entity --><dependency><groupId>com.atguigu.springcloud</groupId><artifactId>cloud-api-commons</artifactId><version>${project.version}</version></dependency><!--一般基础配置类--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-devtools</artifactId><scope>runtime</scope><optional>true</optional></dependency><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><optional>true</optional></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency></dependencies>
3.YML
server:port: 9527spring:application:name: cloud-gatewayeureka:instance:hostname: cloud-gateway-serviceclient: #服务提供者provider注册进eureka服务列表内service-url:register-with-eureka: truefetch-registry: truedefaultZone: http://eureka7001.com:7001/eureka
4.主启动
@SpringBootApplication
@EnableEurekaClient
public class GateWayMain9527 {public static void main(String[] args) {SpringApplication.run(GateWayMain9527.class,args);}
}
5. 路由映射(比如我们想访问8001端口的provider,但又不希望暴露这个端口)
Yml中添加路由属性:
spring:application:name: cloud-gatewaycloud:gateway:routes:- id: payment_routh #payment_route #路由的ID,没有固定规则但要求唯一,建议配合服务名uri: http://localhost:8001 #匹配后提供服务的路由地址predicates:- Path=/payment/get/** # 断言,路径相匹配的进行路由- id: payment_routh2 #payment_route #路由的ID,没有固定规则但要求唯一,建议配合服务名uri: http://localhost:8001 #匹配后提供服务的路由地址predicates:- Path=/payment/lb/** # 断言,路径相匹配的进行路由
6.测试
首先启动 EurekaMain7001、GateWayMain9527、PaymentMain8001
添加网关前的访问路径: http://localhost:8001/payment/get/31
添加网关后的访问路径: http://localhost:9527/payment/get/31
3.2 通过微服务名进行动态路由
默认情况下Gateway会根据注册中心服务列表上的微服务名为路径创建动态路由进行转发,从而实现动态路由的功能
假设我们有两个provider:PaymentMain8001、PaymentMain8002
我们需要在GateWay的YML中进一步修改:
spring:application:name: cloud-gatewaycloud:gateway:discovery:locator:enabled: true #开启从注册中心动态创建路由的功能,利用微服务名进行路由routes:- id: payment_routh #payment_route #路由的ID,没有固定规则但要求唯一,建议配合服务名# uri: http://localhost:8001 #匹配后提供服务的路由地址uri: lb://cloud-payment-service #匹配后提供服务的路由地址predicates:- Path=/payment/get/** # 断言,路径相匹配的进行路由- id: payment_routh2 #payment_route #路由的ID,没有固定规则但要求唯一,建议配合服务名# uri: http://localhost:8001 #匹配后提供服务的路由地址uri: lb://cloud-payment-service #匹配后提供服务的路由地址predicates:- Path=/payment/lb/** # 断言,路径相匹配的进行路由
lb://serviceName是spring cloud gateway在微服务中自动为我们创建的负载均衡URL,表示启用Gateway的负载均衡功能
3.3 Predict的使用
说白了,Predicate就是为了实现一组匹配规则,让请求过来找到对应的Route进行处理。
Predict的类型:
举例:
... ...
predicates:- Path=/payment/lb/**- After=2020-02-05T15:10:03.685+08:00[Asia/Shanghai] # 在这个时间之后的请求生效- Before=2020-02-05T15:10:03.685+08:00[Asia/Shanghai] # 在这个时间之前的请求生效- Between=2020-02-02T17:45:06.206+08:00[Asia/Shanghai],2020-03-25T18:59:06.206+08:00[Asia/Shanghai] #在这两个时间之间的请求生效- Cookie=username,zzyy #需要两个参数,一个是 Cookie name ,一个是正则表达式。路由规则会通过获取对应的 Cookie name 值和正则表达式去匹配,如果匹配上就会执行路由,如果没有匹配上则不执行- Header=X-Request-Id, \d+ # 请求头要有X-Request-Id属性并且值为整数的正则表达式- Host=**.atguigu.com- Method=GET- Query=username, \d+ # 要有参数名username并且值还要是整数才能路由
3.4 Filter的使用
路由过滤器可用于修改进入的HTTP请求和返回的HTTP响应,路由过滤器只能指定路由进行使用。Spring Cloud Gateway 内置了多种路由过滤器,他们都由GatewayFilter的工厂类来产生。
分类:
按照生命周期:
Pre:请求转发前
Post :收到响应后
按照种类:
GateWayFilter:配置在具体路由下
GlobalFilter:不需要在配置文件中配置,作用在所有的路由上
使用格式举例:
... ...
routes:- id: payment_routh #payment_route #路由的ID,没有固定规则但要求唯一,建议配合服务名uri: lb://cloud-provider-payment #匹配后的目标服务地址,供服务的路由地址filters:- AddRequestParameter=X-Request-Id,1024 #过滤器工厂会在匹配的请求头加上一对请求头,名称为X-Request-Id值为1024predicates:- Path=/paymentInfo/** # 断言,路径相匹配的进行路由- Method=GET,POST
3.5 自定义过滤器
自定义全局GlobalFilter的作用:全局日志记录、统一网关鉴权... ...
需要自定义过滤器类,实现 GlobalFilter,Ordered 接口
@Component
public class MyLogGateWayFilter implements GlobalFilter,Ordered
{@Overridepublic Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain){String uname = exchange.getRequest().getQueryParams().getFirst("uname");//获取请求参数if (uname == null) {//名字为空就设置错误响应码然后返回System.out.println("****用户名为null,无法登录");exchange.getResponse().setStatusCode(HttpStatus.NOT_ACCEPTABLE);//设置响应码return exchange.getResponse().setComplete();//返回}return chain.filter(exchange);//名字不为空就继续执行}@Overridepublic int getOrder(){return 0;}
}
SpringCloud-4.服务网关(GateWay)相关推荐
- SpringCloud 微服务网关Gateway 动态路由配置
概述:在上一章节<SpringCloud 微服务网关Gateway介绍及简单路由配置>中我们讲述了Gateway的最简单的路由配置方式.但是其中比较明显的问题就是我们在配置路由服务的地址时 ...
- SpringCloud—— 微服务网关GateWay
目录 1.GateWay网关概述 1.1.什么是GateWay? 1.2.为什么要使用微服务网关? 1.3.Zuul与GateWay网关的区别? 2.快速入门 2.1.创建项目 2.2.配置yml文件 ...
- SpringCloud 微服务网关Gateway介绍及简单路由配置
概述:什么是微服务网关?为了解决用户客户端在调用微服务系统中的多个消费者工程接口时,需要维护非常多的消费者应用接口地址等信息,以及可能存在不同应用见的调用跨域等问题,微服务网关组件随即出现.网关作为用 ...
- 【SpringCloud】服务网关 gateway 和 zuul
文章目录 1.概述 2.特性 3.区别 3. zuul1 模型 4. Spring Cloud Gateway 5. 3大核心概念 6.案例 6.1 案例1 6.1.1 maven 6.1.2 主类 ...
- 博海拾贝--springcloud的组件及使用(3)服务网关 GateWay
Srpingcloud 服务网关 GateWay 前言: Spring Cloud Gateway是springcloud官方推出的第二代网关框架,她包括转发.限流.熔断.权限校验等功能. 本文就来介 ...
- Spring Cloud 终于按捺不住推出了自己的服务网关 Gateway
转载自 Spring Cloud 终于按捺不住推出了自己的服务网关 Gateway Spring 官方最终还是按捺不住推出了自己的网关组件:Spring Cloud Gateway ,相比之前我们使 ...
- Spring Cloud之(十八)微服务网关GateWay
十八.微服务网关GateWay Zuul 1.x 是一个基于阻塞 IO 的 API Gateway 以及 Servlet:直到 2018 年 5 月,Zuul 2.x(基于Netty,也是非阻塞的,支 ...
- SpringCloud:统一网关Gateway
目录 1.网关介绍 2.搭建网关服务 3.路由断言工厂 4.路由过滤器 5.全局过滤器GlobalFilter 6.过滤器执行顺序 7.跨域问题处理 1.网关介绍 网关(Gateway)又称网间连接器 ...
- 微服务_服务网关(Gateway)
目录 一.为什么需要网关 二.SpringCloud网关的实现方式 三.Gateway实践 1)创建gateway服务,引入依赖 2)编写启动类 3)编写基础配置和路由规则 4)重启测试 5)网关路由 ...
- 微服务网关Gateway(七)
前言 zuul目前已经出现了分歧,zuul 升级到 Zuul2的时候出现了内部分歧,并且导致Zuul的核心人员的离职,导致Zuul2一直跳票,等了两年,目前造成的局面是Zuul已经没人维护,Zuul2 ...
最新文章
- python3 词法拆分
- python实现一个字典
- 浅谈javaweb三大框架和MVC设计模式
- 常用的LINQ to SQL 用法
- 第三章 染色动力学理论单元测试
- 基于Java+SpringBoot+vue+element等动物救助平台设计和实现
- 利用制表位快速居中对齐公式,同时公式编号靠右对齐
- 运行报错SecureCRT: error while loading shared libraries: libjpeg.so.8:
- 虚拟机VMware的Ubuntu下安装tensorflow详解
- 翻译连载 | 附录 C:函数式编程函数库-《JavaScript轻量级函数式编程》 |《你不知道的JS》姊妹篇...
- 冰点密码忘记了怎么办
- Java中抽象类和接口的区别 经典(转)
- 【设计原则】软件开发中的原则
- RTC月度小报5月 |教育aPaaS灵动课堂升级、抢先体验VUE版 Agora Web SDK、声网Agora与HTC达成合作
- predefined annotation
- 给定三角形三边,如何判断该三角形的形状
- 关于python的开发软件pycharm设置中文(无需汉化包)
- 张一鸣与腾讯战斗并突围的秘诀:不急
- Profinet远程IO控制器
- 1080P画面大小却是1920*1088的两个原因
热门文章
- 【学习笔记】域名资源记录(Resource Record)
- mysql interval weekday_Mysql DATE_SUB(NOW(), INTERVAL 1 DAY) 24 hours or weekday?
- java数据结构和算法——图的深度优先(DFS)遍历
- android WebView加载视频只有声音没有画面
- Maven基础-Maven的生命周期、命令和插件(6)- mvn test命令详解
- js 混合排序(同时存在数字、字母、汉字等)
- PTA python 币值转换 ,逆序数
- 虚拟华尔街的最新资讯 虚拟经济体的最新经济体
- FFmpeg 集成 x265 编译及解码
- For Your Dream