微服务网关

平台中部署了很多微服务,这些微服务对外提供 API 接口以便客户端
调用,每个微服务都有各自的地址、端口等信息,一个客户端可能需
要访问很多不同的微服务去实现业务功能。这就需要客户端动态维护
微服务的信息并与多个微服务之间进行身份验证工作,为了解决这些
问题,就需要一个能够统一管理 API 的网络关口,作为整个微服务
平台请求的唯一入口,在网关层处理所有非业务功能(比如对调用微
服务的客户端进行身份验证、记录日志、动态路由等),本方案采用
Spring 官方推出的 Spring Cloud Gateway 网关组件,具有如下特
性:

是基于 Spring Framework 5 和 Spring Boot 2.x 的响应式、
非阻塞式的 API;

动态路由:能够匹配任何请求属性;

可以对路由指定 Predicate(断言)和 Filter(过滤器);

集成 Hystrix 的断路器功能;

集成 Spring Cloud 服务发现功能;

易于编写的 Predicate(断言)和 Filter(过滤器);

请求限流功能;

支持路径重写。
客户端向 Spring Cloud Gateway 发出请求。如果 Gateway Handler
Mapping 确定请求与路由匹配,则将其发送到 Gateway Web Handler。
此 handler 通过特定于该请求的过滤器链处理请求。而这些匹配是由
路由断言 Factory 完成的,Spring Cloud Gataway 包含了很多内置 的
路由断言 Factories,这些断言都匹配 HTTP 请求的不同属性。多
个路由断言 Factories 可以通过 and 进行组合使用。
主要内置断言 Factory 包括:

After 路由断言 Factory,After Route Predicate Factory
采用一个参数---日期时间。在该日期时间之后发生的请求都将被
匹配;

Before 路由断言 Factory,Before Route Predicate Factory
采用一个参数---日期时间。在该日期时间之前发生的请求都将被
匹配;

Between 路由断言 Factory,Between 路由断言 Factory 有两
个参数,datetime1 和 datetime2。在 datetime1 和 datetime2 之
间的请求将被匹配。datetime2 参数的实际时间必须在 datetime1
之后;

Cookie 路由断言 Factory, Cookie 路由断言 Factory 有两个
参数,cookie 名称和正则表达式。请求包含次 cookie 名称且正则
表达式为真的将会被匹配;

Header 路由断言 Factory,Header 路由断言 Factory 有两个
参数,header 名称和正则表达式。请求包含次 header 名称且正则
表达式为真的将会被匹配;

Host 路由断言 Factory, Host 路由断言 Factory 包括一个参
数:host name 列表。使用 Ant 路径匹配规则,.作为分隔符; •
Method 路由断言 Factory,Method 路由断言 Factory 只包含
一个参数: 需要匹配的 HTTP 请求方式;

Path 路由断言 Factory,Path 路由断言 Factory 有 2 个参数:
一个 Spring PathMatcher 表达式列表和可选;

Query 路由断言 Factory,Query 路由断言 Factory 有 2 个参
数: 必选项 param 和可选项 regexp;

RemoteAddr 路 由 断 言 Factory,RemoteAddr 路 由 断 言
Factory 的参数为 一个 CIDR 符号(IPv4 或 IPv6)字符串的列表,
最小值为 1,例如 192.168.0.1/16(其中 192.168.0.1 是 IP 地址
并且 16 是子网掩码)
另外,Spring Cloud Gateway 可以与 Oauth2、JWT 集成实现在网关
进行请求的身份验证与授权功能。

相关推荐
梵高的代码色盘18 小时前
互联网大厂Java求职面试实录与技术深度解析
java·spring·缓存·微服务·面试·互联网大厂·技术深度
马士兵教育18 小时前
AI大模型通用智能体项目从原理到落地:Agent Skills 的核心逻辑与中间件 + 动态工具实践方案+架构项目实战!
人工智能·中间件·架构
Blossom.11820 小时前
用纯 NLP 打造「零样本」时序预测模型:文本化序列 + LLM 的实战路线
人工智能·python·深度学习·机器学习·自然语言处理·架构·transformer
Aloudata20 小时前
破局 AI 幻觉:构建以 NoETL 语义编织为核心的 AI 就绪数据架构
人工智能·架构·数据分析·dataagent
GIOTTO情20 小时前
Infoseek 媒介投放系统技术架构解析:高可用与智能化落地实践
架构
信码由缰21 小时前
JExten:基于Java模块系统(JPMS)构建健壮的插件架构
java·开发语言·架构
上海控安21 小时前
蓝牙协议栈架构概述
网络安全·架构
Python_Study202521 小时前
工程材料企业如何通过智慧获客软件破解市场困局:方法论、架构与实践
大数据·网络·数据结构·人工智能·架构
代码写到35岁21 小时前
【Java 单体架构改造 微服务 网关遇坑之 跨域配置】
java·微服务·架构
Fnetlink11 天前
零信任架构在移动办公中的应用与安全保障
安全·架构