SpringCloud 网关 您所在的位置:网站首页 网关未激活什么意思 SpringCloud 网关

SpringCloud 网关

2024-07-02 14:04| 来源: 网络整理| 查看: 265

官网地址:https://spring.io/projects/spring-cloud-gateway

概括简介

Cloud全家桶中有个很重要的组件就是网关,在1.x版本中都是采用Zuul网关;但是在2.x版本中,zuul的升级迟迟未更新,Spring Cloud最后自己研发了一个网关代替zuul, 那就是Spring Cloud GateWay

GateWay基本介绍

网关在微服务系统架构的位置如下图: 在这里插入图片描述 以下是来自官网的翻译: https://cloud.spring.io/spring-cloud-static/spring-cloud-gateway/2.2.2.RELEASE/reference/html/ Gate 在这里插入图片描述 Spring Cloud GateWay 是基于WebFlux框架 ,使用Reactor模式, 而WebFlux框架底层使用的Netty.

GateWay源码架构: 在这里插入图片描述

GateWay作用 反向代理鉴权流量控制熔断日志监控… 微服务网关所处的位置

在这里插入图片描述

zuul 和 gateway 各自特点和区别

在这里插入图片描述

SpringCloud GateWay 特征

在这里插入图片描述

SpringCloud GateWay 和 Zuul 区别

在这里插入图片描述

Zuul1.x模型

Spring Cloud集成Zuul1版本,采用的是Tomcat容器,使用的是传统的Servlet IO处理模型。 Servlet由Servlet container进行生命周期管理, 在这里插入图片描述 在这里插入图片描述

#### GateWay 模型

Spring Cloud GateWay 是基于WebFlux框架 ,使用Reactor模式, 而WebFlux框架底层使用的Netty 在这里插入图片描述

GateWay三大核心概念 Route(路由)

路由是构建网关 的基本模块,它有ID,目标URI,一系列的断言过滤器组成,如果断言为true则配备该路由

Predicate(断言)

在这里插入图片描述

Filter(过滤)

Filter 指的是Spring框架中GatewayFilter的实例,使用过滤器,可以在请求前或者之后对请求进行修改

GateWay三大核心示意图

在这里插入图片描述

GateWay 工作流程

官网的工作流程图: 在这里插入图片描述 在这里插入图片描述

GateWay核心逻辑:路由转发 + 执行过滤器链

GateWay入门配置

新建一个springboot模块:springcloud-gateway9527

添加依赖

org.springframework.cloud spring-cloud-starter-gateway org.springframework.cloud spring-cloud-starter-netflix-eureka-client

yml配置文件添加配置

server: port: 9527 spring: application: name: cloud-gateway cloud: gateway: # 路由集合 routes: - id: payment_routh #payment_route #路由的ID,没有固定规则但要求唯一,建议配合服务名 uri: http://localhost:8003 #匹配后提供服务的路由地址 predicates: - Path=/payment/get/** # 断言,路径相匹配的进行路由 - id: payment_routh2 #payment_route #路由的ID,没有固定规则但要求唯一,建议配合服务名 uri: http://localhost:8002 #匹配后提供服务的路由地址 predicates: - Path=/order/getPaymenttimeoutById/** # 断言,路径相匹配的进行路由 #- After=2020-02-21T15:51:37.485+08:00[Asia/Shanghai] #- Cookie=username,zzyy #- Header=X-Request-Id, \d+ # 请求头要有X-Request-Id属性并且值为整数的正则表达式 eureka: instance: hostname: cloud-gateway-service client: #服务提供者provider注册进eureka服务列表内 service-url: register-with-eureka: true fetch-registry: true defaultZone: http://localhost:7001/eureka

主启动类

@EnableEurekaClient @SpringBootApplication public class SpringcloudGateway9527Application {

启动测试:

通过gateway网关 访问 8003 端口的微服务成功 在这里插入图片描述

GateWay动态路由

通过微服务名实现动态路由

默认情况下Gateway 会根据注册中心注册的服务列表,以注册中心上的微服务名为路径创建动态路由进行转发,从而实现动态路由功能(能负载均衡)

路由配置修改(负载均衡)

我们只需要修改YML配置文件

需要注意的是uri的协议为lb,表示启用Gateway的负载均衡功能。

lb://serviceName

gateway在微服务中自动为我们创建负载均衡uri

注意:注意添加 discovery.locator.enabled=true表示开启从注册中心动态创建路由的功能,利用微服务名进行路由

或者在主启动类加上@EnableDiscoveryClient 表示开启服务注册和发现

@EnableDiscoveryClient @SpringBootApplication public class FyjmallGatewayApplication {

uri: lb://cloud-payment-service 表示匹配后提供服务的路由地址, cloud-payment-service是注册中心上的微服务名

spring: application: name: cloud-gateway cloud: gateway: discovery: locator: enabled: true #开启从注册中心动态创建路由的功能,利用微服务名进行路由 # 路由集合 routes: - id: payment_routh #payment_route #路由的ID,没有固定规则但要求唯一,建议配合服务名 uri: lb://cloud-payment-service #匹配后提供服务的路由地址 # uri: http://localhost:8003 #匹配后提供服务的路由地址 predicates: - Path=/payment/get/** # 断言,路径相匹配的进行路由 - id: payment_routh2 #payment_route #路由的ID,没有固定规则但要求唯一,建议配合服务名 uri: lb://cloud-payment-service #匹配后提供服务的路由地址 # uri: http://localhost:8002 #匹配后提供服务的路由地址 predicates: - Path=/order/getPaymenttimeoutById/** # 断言,路径相匹配的进行路由 路由先后顺序

路由断言匹配 是按照 配置的先后顺序的,如果路由配置断言匹配先匹配上,那么久进行路由,接下来的路由就不会走了

以上配置就能实现动态路由,实现负载均衡的功能

GateWay Predicate(断言)

我们先看上面我们的配置,如下图红框总的predicate配置,表示对路径进行配,如果路径匹配成功就进行路由,匹配不成功就不进行路由,相当于进行的断言判断 在这里插入图片描述

官网Predicate配置,官网地址:

https://cloud.spring.io/spring-cloud-static/spring-cloud-gateway/2.2.2.RELEASE/reference/html/#gateway-request-predicates-factories

官网配置截图: 在这里插入图片描述

常用的 Route Predicate: 在这里插入图片描述 对应的在yml配置: 在这里插入图片描述 在这里插入图片描述

注意predicates: 下面可以配置多个断言规则如下图: 在这里插入图片描述 更多Predicate配置请参考官网

GateWay 过滤器(Filter)

在这里插入图片描述

GateWay Filter 只能在业务逻辑之前,和业务逻辑之后GateWay Filter 种类分为 单一的 GateWayFilter 和全局的 GlobalFilter

官网的GateWay Filter有很多,具体可以参考官网:

单一GateWay Filter配置如下截图: 在这里插入图片描述 在这里插入图片描述

注意 AddRequestParameter 参数表示添加请求参数,还有许多这样的参数配置,请参考官网。

自定义全局过滤器

自定义过滤器要实现2个接口,GlobalFilter,Ordered

主要能够实现全局日志记录,统一网关鉴权等…

案例代码:

@Component public class MyGlobalFilter implements GlobalFilter,Ordered { @Override public Mono filter(ServerWebExchange exchange, GatewayFilterChain chain) { String username = exchange.getRequest().getQueryParams().getFirst("username"); if (username == null) { exchange.getResponse().setStatusCode(HttpStatus.NOT_ACCEPTABLE); return exchange.getResponse().setComplete(); } // 放行 return chain.filter(exchange); } // 表示排名 @Override public int getOrder() { return 0; } }

在这里插入图片描述 测试:

请求带有参数username,可以成功访问

在这里插入图片描述

请求没有带有参数username,无法访问 在这里插入图片描述

或者参数

总结:

通过以上案例,我们可以自己定义全局GlobalFilter,对请求进行过滤,可以根据我们自己的定义的规则来过滤每一个请求



【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有