GateWay简介

⽹关(翻译过来就叫做GateWay):微服务架构中的重要组成部分。局域⽹中就有⽹关这个概念,局域⽹接收或者发送数据出去通过这个⽹关,⽐如⽤ Vmware 虚拟机软件搭建虚拟机集群的时候,往往我们需要选择IP段中的⼀个IP作为⽹关地址。

Spring Cloud GateWay是Spring Cloud的⼀个全新项⽬,⽬标是取代Netflflix Zuul,它基于Spring5.0+SpringBoot2.0+WebFlux(基于⾼性能的Reactor模式响应式通信框架Netty,异步⾮阻塞模型)等技术开发,性能⾼于Zuul,官⽅测试,GateWay是Zuul的1.6倍,旨在为微服务架构提供⼀种简单有效的统⼀的API路由管理⽅式。Spring Cloud GateWay不仅提供统⼀的路由⽅式(反向代理)并且基于 Filter(定义过滤器对请求过滤,完成⼀些功能) 链的⽅式提供了⽹关基本的功能,例如:鉴权、流量控制、熔断、路径重写、⽇志监控等

⽹关在架构中的位置,如下图

nginx 负载均衡器(高可用的nginx 集群),这里的 Nginx 完成的是对下游网关组件的负载,实现gateway 的高可用。

Spring Cloud GateWay 天⽣就是异步⾮阻塞的,基于Reactor模型。⼀个请求—>⽹关根据⼀定的条件匹配—匹配成功之后可以将请求转发到指定的服务地址;⽽在这个过程中,我们可以进⾏⼀些⽐较具体的控制(限流、⽇志、⿊⽩名单)。

  • 路由(route): ⽹关最基础的部分,也是⽹关⽐较基础的⼯作单元。路由由⼀个ID、⼀个⽬标URL(最终路由到的地址)、⼀系列的断⾔(匹配条件判断)和Filter过滤器(精细化控制)组成。如果断⾔为true,则匹配该路由。
  • 断⾔(predicates):参考了Java8中的断⾔java.util.function.Predicate,开发⼈员可以匹配Http请求中的所有内容(包括请求头、请求参数等)(类似于nginx中的location匹配⼀样),如果断⾔与请求相匹配则路由。
  • 过滤器(fifilter):⼀个标准的Spring webFilter,使⽤过滤器,可以在请求之前或者之后执⾏业务逻辑。

来⾃官⽹的⼀张图

其中,Predicates断⾔就是我们的匹配条件,⽽Filter就可以理解为⼀个⽆所不能的拦截器,有了这两个元素,结合⽬标URL,就可以实现⼀个具体的路由转发。

GateWay⼯作过程

官网提供的工作流程图。

客户端向 Spring Cloud GateWay发出请求,然后在 GateWay Handler Mapping 中找到与请求相匹配的路由,将其发送到GateWay Web Handler;Handler再通过指定的过滤器链来将请求发送到我们实际的服务执⾏业务逻辑,然后返回。过滤器之间⽤虚线分开是因为过滤器可能会在发送代理请求之前(pre)或者之后(post)执⾏业务逻辑。

Filter在“pre”类型过滤器中可以做参数校验、权限校验、流量监控、⽇志输出、协议转换等,在“post”类型的过滤器中可以做响应内容、响应头的修改、⽇志的输出、流量监控等。

GateWay核⼼逻辑:路由转发+执⾏过滤器链。

GateWay应⽤

GateWay 不需要使⽤ web 模块,它引⼊的是 WebFlux(类似于SpringMVC)。

依赖

pom.xml 文件如下:

<dependencies><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-commons</artifactId></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-client</artifactId></dependency><!--GateWay 网关--><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-gateway</artifactId></dependency><!--引入webflux--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-webflux</artifactId></dependency><!--日志依赖--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-logging</artifactId></dependency><!--测试依赖--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency><!--lombok工具--><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>1.18.4</version><scope>provided</scope></dependency><!--引入Jaxb,开始--><dependency><groupId>com.sun.xml.bind</groupId><artifactId>jaxb-core</artifactId><version>2.2.11</version></dependency><dependency><groupId>javax.xml.bind</groupId><artifactId>jaxb-api</artifactId></dependency><dependency><groupId>com.sun.xml.bind</groupId><artifactId>jaxb-impl</artifactId><version>2.2.11</version></dependency><dependency><groupId>org.glassfish.jaxb</groupId><artifactId>jaxb-runtime</artifactId><version>2.2.10-b140310.1920</version></dependency><dependency><groupId>javax.activation</groupId><artifactId>activation</artifactId><version>1.1.1</version></dependency><!--引入Jaxb,结束--><!-- Actuator可以帮助你监控和管理Spring Boot应用--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-actuator</artifactId></dependency><!--热部署--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-devtools</artifactId><optional>true</optional></dependency><!--链路追踪--><!--<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-sleuth</artifactId></dependency>-->
</dependencies><dependencyManagement><!--spring cloud依赖版本管理--><dependencies><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-dependencies</artifactId><version>Greenwich.RELEASE</version><type>pom</type><scope>import</scope></dependency></dependencies>
</dependencyManagement>

配置

server:port: 9002
eureka:client:serviceUrl: # eureka server的路径defaultZone: http://democloudeurekaservera:8761/eureka/,http://democloudeurekaserverb:8762/eureka/ #把 eureka 集群中的所有 url 都填写了进来,也可以只写一台,因为各个 eureka server 可以同步注册表instance:#使用ip注册,否则会使用主机名注册了(此处考虑到对老版本的兼容,新版本经过实验都是ip)prefer-ip-address: true#自定义实例显示格式,加上版本号,便于多版本管理,注意是ip-address,早期版本是ipAddressinstance-id: ${spring.cloud.client.ip-address}:${spring.application.name}:${server.port}:@project.version@
spring:application:name: lagou-cloud-gatewaycloud:gateway:routes: # 路由可以有多个- id: service-autodeliver-router # 我们自定义的路由 ID,保持唯一#uri: http://127.0.0.1:8096  # 目标服务地址  自动投递微服务(部署多实例)  动态路由:uri配置的应该是一个服务名称,而不应该是一个具体的服务实例的地址uri: lb://demo-service-autodeliver                                                                    # gateway网关从服务注册中心获取实例信息然后负载后路由predicates:                                         # 断言:路由条件,Predicate 接受一个输入参数,返回一个布尔值结果。该接口包含多种默 认方法来将 Predicate 组合成其他复杂的逻辑(比如:与,或,非)。- Path=/autodeliver/**- id: service-resume-router      # 我们自定义的路由 ID,保持唯一#uri: http://127.0.0.1:8081       # 目标服务地址#http://localhost:9002/resume/openstate/1545132#http://127.0.0.1:8081/openstate/1545132uri: lb://demo-service-resume# 断言:路由条件,Predicate 接受一个输入参数,返回一个布尔值结果。该接口包含多种默 认方法来将 Predicate 组合成其他复杂的逻辑(比如:与,或,非)。predicates:- Path=/resume/**filters:- StripPrefix=1

上⾯这段配置的意思是,配置了⼀个 id 为 service-autodeliver-router 的路由规则,当向⽹关发起

请求

 http://localhost:9002/autodeliver/checkAndBegin/1545132

请求会被分发路由到对应的微服务上。

GateWay路由规则详解

Spring Cloud GateWay 帮我们内置了很多 Predicates功能,实现了各种路由匹配规则(通过Header、请求参数等作为条件)匹配到对应的路由。

时间点后匹配

spring:cloud:gateway:routes:- id: after_routeuri: https://example.orgpredicates:- After=2017-01-20T17:42:47.789-07:00[America/Denver]

时间点前匹配

spring:cloud:gateway:routes:- id: after_routeuri: https://example.orgpredicates:- Before=2017-01-20T17:42:47.789-07:00[America/Denver]

时间区间匹配

spring:cloud:gateway:routes:- id: after_routeuri: https://example.orgpredicates:- Between=2017-01-20T17:42:47.789-07:00[America/Denver], 2017-01-21T17:42:47.789-07:00[America/Denver]

指定Cookie正则匹配指定值

spring:cloud:gateway:routes:- id: after_routeuri: https://example.orgpredicates:- Cookie=chocolate, ch.p

指定Header正则匹配指定值

spring:cloud:gateway:routes:- id: after_routeuri: https://example.orgpredicates:-  Header=X-Request-Id, \d+

请求Host匹配指定值

spring:cloud:gateway:routes:- id: after_routeuri: https://example.orgpredicates:-   Host=**.somehost.org,**.anotherhost.org

请求Method匹配指定请求⽅式

spring:cloud:gateway:routes:- id: after_routeuri: https://example.orgpredicates:- Method=GET,POST

请求路径正则匹配

spring:cloud:gateway:routes:- id: after_routeuri: https://example.orgpredicates:- Path=/red/{segment},/blue/{segment}

请求包含某参数

spring:cloud:gateway:routes:- id: after_routeuri: https://example.orgpredicates:- Query=green

请求包含某参数并且参数值匹配正则表达式

spring:cloud:gateway:routes:- id: after_routeuri: https://example.orgpredicates:- Query=red, gree.

远程地址匹配

spring:cloud:gateway:routes:- id: after_routeuri: https://example.orgpredicates:- RemoteAddr=192.168.1.1/24

GateWay⽀持⾃动从注册中⼼中获取服务列表并访问,即所谓的动态路由

实现步骤如下

1)pom.xml中添加注册中⼼客户端依赖(因为要获取注册中⼼服务列表,eureka客户端已经引⼊)

2)动态路由配置

uri: lb://demo-service-resume

注意:动态路由设置时,uri 以 lb: // 开头( lb 代表从注册中⼼获取服务),后⾯是需要转发到的服务名称

GateWay过滤器

从过滤器⽣命周期(影响时机点)的⻆度来说,主要有两个pre和post:

  • pre:这种过滤器在请求被路由之前调⽤。我们可利⽤这种过滤器实现身份验证、在集群中选择 请求的微服务、记录调试信息等。

  • post:这种过滤器在路由到微服务以后执⾏。这种过滤器可⽤来为响应添加标准的 HTTPHeader、收集统计信息和指标、将响应从微服务发送给客户端等。

从过滤器类型的⻆度,Spring Cloud GateWay 的过滤器分为 GateWayFilter 和 GlobalFilter 两种

  • GateWayFilter :应⽤到单个路由路由上

  • GlobalFilter :应⽤到所有的路由上

在Gateway Filter可以去掉url中的占位后转发路由,⽐如

predicates:- Path=/resume/**filters:- StripPrefix=1 # 可以去掉resume之后转发

⿊⽩名单

请求过来时,判断发送请求的客户端的ip,如果在⿊名单中,拒绝访问⾃定义GateWay全局过滤器时,我们实现Global Filter接⼝即可,通过全局过滤器可以实现⿊⽩名单、限流等功能。

/*** 定义全局过滤器,会对所有路由生效*/
@Slf4j
@Component  // 让容器扫描到,等同于注册了
public class BlackListFilter implements GlobalFilter, Ordered {// 模拟黑名单(实际可以去数据库或者redis中查询)private static List<String> blackList = new ArrayList<>();static {blackList.add("0:0:0:0:0:0:0:1");  // 模拟本机地址}/*** 过滤器核心方法* @param exchange 封装了request和response对象的上下文* @param chain 网关过滤器链(包含全局过滤器和单路由过滤器)* @return*/@Overridepublic Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {// 思路:获取客户端ip,判断是否在黑名单中,在的话就拒绝访问,不在的话就放行// 从上下文中取出request和response对象ServerHttpRequest request = exchange.getRequest();ServerHttpResponse response = exchange.getResponse();// 从request对象中获取客户端ipString clientIp = request.getRemoteAddress().getHostString();// 拿着clientIp去黑名单中查询,存在的话就决绝访问if(blackList.contains(clientIp)) {// 决绝访问,返回response.setStatusCode(HttpStatus.UNAUTHORIZED); // 状态码log.debug("=====>IP:" + clientIp + " 在黑名单中,将被拒绝访问!");String data = "Request be denied!";DataBuffer wrap = response.bufferFactory().wrap(data.getBytes());return response.writeWith(Mono.just(wrap));}// 合法请求,放行,执行后续的过滤器return chain.filter(exchange);}/*** 返回值表示当前过滤器的顺序(优先级),数值越小,优先级越高* @return*/@Overridepublic int getOrder() {return 0;}
}

GateWay⾼可⽤

⽹关作为⾮常核⼼的⼀个部件,如果挂掉,那么所有请求都可能⽆法路由处理,因此我们需要做GateWay的⾼可⽤。

GateWay 的⾼可⽤很简单:可以启动多个GateWay实例来实现⾼可⽤,在GateWay的上游使⽤Nginx 等负载均衡设备进⾏负载转发以达到⾼可⽤的⽬的。启动多个GateWay实例(假如说两个,⼀个端⼝9002,⼀个端⼝9003),剩下的就是使⽤Nginx等完

成负载代理即可。示例如下

#配置多个GateWay实例
upstream gateway {server 127.0.0.1:9002;server 127.0.0.1:9003;
}
location / {proxy_pass http://gateway;
}

总结

Gateway 可以用来统一对外接口,权限校验、黑白名单等等。在spring cloud 微服务架构中是必不可少的,大家赶紧 get 吧

GateWay 网关服务相关推荐

  1. Gateway—网关服务

    ⼀.网关介绍 使用服务网关作为接口服务的统⼀代理,前端通过网关完成服务的统⼀调用 网关可以干什么? 路由:接口服务的统⼀代理,实现前端对接⼝服务的统⼀访问 过滤:对用户请求进行拦截.过滤(用户鉴权). ...

  2. gateway网关服务的高级配置

    源码:学习demo: 关于学习的所有代码 目录: gateway网关的断言工厂 gateway网关的过滤器工厂 gateway网关的全局过滤器,即可以自定义业务代码的过滤器 一.gateway网关的断 ...

  3. Spring Cloud Alibaba 快速入门(七):Gateway微服务网关

    前言:在微服务架构中,有一个组件可以说是必不可少的,那就是微服务网关.微服务网关处理了路由转发,负载均衡,缓存,权限校验,监控,限流控制,日志等.Spring Cloud Gateway是Spring ...

  4. SpringCloudAlibaba之gateway网关

    1. Gateway 1.1. 什么是网关 1.1.1. 网关的功能 身份认证 权限校验 服务路由 负载均衡 请求限流 1.1.2. Spring Cloud网关落地方案 Zuul是基于Servlet ...

  5. SpringCloud - Spring Cloud 之 Gateway网关(十三)

    阅读本文前可先参考 ​​​​​​SpringCloud - Spring Cloud根/父项目,开发准备(二)_MinggeQingchun的博客-CSDN博客 一.API网关 引自百度百科 API网 ...

  6. SpringCloud + Consul服务注册中心 + gateway网关

    1  启动Consul 2  创建springcloud-consul项目及三个子模块 2.1 数据模块consul-producer 2.2 数据消费模块consul-consumer 2.3 ga ...

  7. SpringCloud 2020版本教程2:使用spring cloud gateway作为服务网关

    点击关注公众号,Java干货及时送达 Spring Cloud Gateway是Spring Cloud官方推出的第二代网关框架,取代Zuul网关.网关作为流量的,在微服务系统中有着非常作用,网关常见 ...

  8. SpringCloud微服务架构之,Hystrix 熔断器,Gateway 网关

    Hystrix 概述 Hystix 是 Netflix 开源的一个延迟和容错库,用于隔离访问远程服务.第三方库,防止出现级联失败(雪崩). pom依耐 <!-- hystrix -->&l ...

  9. spring cloud gateway 网关_微服务网关Spring Cloud Gateway全搞定

    一.微服务网关Spring Cloud Gateway 1.1 导引 文中内容包含:微服务网关限流10万QPS.跨域.过滤器.令牌桶算法. 在构建微服务系统中,必不可少的技术就是网关了,从早期的Zuu ...

  10. SpringCloud Hoxton版微服务- Gateway网关

    Gateway网关 一.Gateway概念 二.三大核心概念 1.Route (路由) 2.Predicate (断言) 3.Filter (过滤) 三.工作流程图 四.工程搭建 1.新建Gatewa ...

最新文章

  1. 推荐一位大佬,在腾讯工作十年
  2. php导出csv数据在浏览器中输出提供下载或保存到文件的示例
  3. pycharm设置字体和背景色
  4. php 数组xml,php 数组转xml的例子
  5. PYTHON解析XML的多种方式效率对比实测
  6. python在web可以开发吗_怎么用python进行web开发
  7. visualmap超过范围改变颜色_换种颜色,换种心情——车身改色
  8. C++基础:第四章 数组、vector和字符串
  9. 微信客户端抽奖转盘效果
  10. 【优化算法】杂草优化算法(IWO)【含Matlab源码 1076期】
  11. Aps.Net js ymPrompt消息提示组件4.0版
  12. ADXL362加速度传感器使用记录
  13. win10系统设置插入鼠标禁用触控板的方法
  14. 2020央行全面降准,货币政策操作仍有较大空间
  15. 初来乍到,余生请多指教
  16. [渝粤教育] 四川轻化工大学 化工设备机械基础 参考 资料
  17. Redis资料汇总(二) 数据类型
  18. 【XBEE手册】ZigBee网络
  19. R语言时间序列分析-根据aic值选择arima模型
  20. AssetsManager下载类

热门文章

  1. python中from import_Python中的import和from import
  2. C++ advanced(4)make function and SFINAE
  3. arm mali 天梯图_手机CPU天梯图2017年上半年新版 2017手机cpu性能排行天梯图
  4. XCTF WEB mfw
  5. mysql查看表内容 很乱_mysql数据表字符混乱问题解决办法
  6. Ubuntu18.04 + win10 双系统,grub引导配置,美化
  7. 爬虫--破解验证码的几种方式
  8. ssci源刊里有开源期刊吗_2020年SCI期刊影响因子重磅发布!你投过的期刊涨了吗?...
  9. [摘录]第二部分 战略决策(1)
  10. mysql还原报错[err]1153解决办法