Spring Cloud Gateway微服务网关快速入门
创始人
2024-03-04 21:20:27
0

介绍

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 链的方式提供了网关基本的功能,例如:安全,监控,和限流等。
在这里插入图片描述

  • 网关的配置可以和nacos集成实现动态路由配置,具体可以看我的另一篇文章:
    【Spring Cloud Gateway集成Nacos实现动态路由】
    在这里插入图片描述

工作原理

下图从总体上概述了Spring Cloud Gateway的工作方式:
在这里插入图片描述
客户端向 Spring Cloud Gateway 发出请求。然后在 Gateway Handler Mapping 中找到与请求相匹配的路由,将其发送到 Gateway Web Handler。Handler 再通过指定的过滤器链来将请求发送到我们实际的服务执行业务逻辑,然后返回。过滤器之间用虚线分开是因为过滤器可能会在发送代理请求之前(pre)或之后(post)执行业务逻辑。

核心术语

  • Route(路由):这是网关的基本构建块。它由一个 ID,一个目标 URI,一组断言和一组过滤器定义。如果断言为真,则路由匹配。
  • Predicate(断言):这是一个 Java 8 的 Predicate。输入类型是一个 ServerWebExchange。我们可以使用它来匹配来自 HTTP 请求的任何内容,例如 headers 或参数。
  • Filter(过滤器):这是org.springframework.cloud.gateway.filter.GatewayFilter的实例,我们可以使用它修改请求和响应。

牛刀小试

下面以一个简单的例子展示Gateway的用法。完整代码看文章最后。

1. 创建网关服务microservice-gateway

  • 注意:Spring Cloud Gateway 不使用 Web 作为服务器,而是 使用 WebFlux 作为服务器 (本质是通过netty的io多路复用通信),Gateway 项目已经依赖了 starter-webflux,所以这里不要依赖 starter-web。


org.springframework.cloudspring-cloud-starter-gateway


  • 创建配置文件
server:port: 7000spring:application:name: microservice-gatewaycloud:gateway:routes:- id: router1 # 路由的IDuri: http://localhost:9000/user/{id} # 匹配后路由地址predicates: # 断言, 路径相匹配的进行路由- Path=/user/{id}

2.创建服务microservice-user

网关匹配后跳转到改服务接口。

org.springframework.bootspring-boot-starter-web
  • 编写配置文件
server:port: 9000
  • 编写UserController
@RestController
public class UserController {@GetMapping("/user/{id}")public String hello(@PathVariable String id){return "Hello, user"+ id;}
}

3.测试

  • 启动microservice-gateway
  • 启动microservice-user
    谷歌浏览器访问:localhost:7000/user/2

在这里插入图片描述

项目源码

https://gitee.com/indexman/microservice-learn

相关内容

热门资讯

监控摄像头接入GB28181平... 流程简介将监控摄像头的视频在网站和APP中直播,要解决的几个问题是:1&...
Windows10添加群晖磁盘... 在使用群晖NAS时,我们需要通过本地映射的方式把NAS映射成本地的一块磁盘使用。 通过...
protocol buffer... 目录 目录 什么是protocol buffer 1.protobuf 1.1安装  1.2使用...
在Word、WPS中插入AxM... 引言 我最近需要写一些文章,在排版时发现AxMath插入的公式竟然会导致行间距异常&#...
【PdgCntEditor】解... 一、问题背景 大部分的图书对应的PDF,目录中的页码并非PDF中直接索引的页码...
Fluent中创建监测点 1 概述某些仿真问题,需要创建监测点,用于获取空间定点的数据࿰...
educoder数据结构与算法...                                                   ...
MySQL下载和安装(Wind... 前言:刚换了一台电脑,里面所有东西都需要重新配置,习惯了所...
修复 爱普生 EPSON L4... L4151 L4153 L4156 L4158 L4163 L4165 L4166 L4168 L4...
MFC文件操作  MFC提供了一个文件操作的基类CFile,这个类提供了一个没有缓存的二进制格式的磁盘...