网站首页 > 教程文章 正文
微服务网关是微服务比较重要的核心组件,今天我就全面来详解微服务网关(Gateway)@mikechen
本篇已收于mikechen原创超30万字《阿里架构师进阶专题合集》里面。
Gateway网关
Gateway是Spring Cloud的一个全新的API网关项目,是Spring官方基于Spring 5.0、Spring Boot 2.0、Project Reactor等技术开发的网关。
Gateway网关作用
传统的单体架构中只需要开放一个服务给客户端调用,但是微服务架构中是将一个系统拆分成多个微服务。
每一个微服务都会部署到内网服务器中,或者禁止外部访问这些端口,这是对应用的一种安全保护机制。
因此,我们如果想通过互联网来访问这些服务,需要一个统一的入口:这就Gateway服务网关。
Gateway是用于微服务场景的网关组件,旨在提供一种简单而有效的方法来作为API服务的路由,并为它们提供各种增强功能,例如:安全性,监控和可伸缩性。
Gateway网关功能
Gateway网关是一种简单而有效的方式对API进行路由,以及提供一些强大的过滤器功能,如下图所示:
例如包含上图中的Gateway功能:
- 服务路由;
- 安全认证;
- 流量控制;
- 日志监控;
- 熔断保护等功能。
Gateway网关原理
它的工作原理如下图所示:
客户端将请求发给Spring Cloud Gateway,如果Gateway handle mapping 确定这个请求和一个路由匹配,它将此请求发给 Gateway web handle。
这个 Gateway web handle运行这个请求,通过一个filter chain,这个 filter chain在请求路由前后都能执行。
简单而言就是通过一连串的Filter处理匹配到特定规则Predicates的请求。
所以最主要就是做了两件事:
1)哪些请求可以被它处理,由Predicates决定;
2)如何处理由Filters决定。
Gateway网关流程
Gateway网关流程执行流程,如下图所示:
Gateway网关流程执行流程,大致分为如下6步:
- Gateway Client向Gateway Server发送请求;
- 请求首先会被HttpWebHandlerAdapter进行提取组装成网关上下文;
- 然后网关的上下文会传递到DispatcherHandler,它负责将请求分发给 RoutePredicateHandlerMapping;
- RoutePredicateHandlerMapping负责路由查找,并根据路由断言判断路由是否可用;
- 如果过断言成功,由FilteringWebHandler创建过滤器链并调用;
- 请求会一次经过PreFilter--微服务--PostFilter的方法,最终返回响应。
以上
本篇已收于mikechen原创超30万字《阿里架构师进阶专题合集》里面。
猜你喜欢
- 2025-07-08 对API网关注册和接入的接口安全管理总结
- 2025-07-08 什么是API网关?——驱动数字化转型的“隐形冠军”
- 2025-07-08 27 | API网关:系统的门面要如何做呢?
- 2025-07-08 什么是网关服务?(到底什么是网关)
- 2025-07-08 网关的作用与设计介绍(网关的用途)
- 2025-07-08 天天写CRUD的你,到了该给系统接入API网关的时候了
- 2025-07-08 什么是API网关?对企业为何重要?(api网关管理系统)
- 2025-07-08 其实,对于微服务网关的主要功能和技术选型,你还需要深入理解下
- 最近发表
- 标签列表
-
- location.href (44)
- document.ready (36)
- git checkout -b (34)
- 跃点数 (35)
- 阿里云镜像地址 (33)
- qt qmessagebox (36)
- mybatis plus page (35)
- vue @scroll (38)
- 堆栈区别 (33)
- 什么是容器 (33)
- sha1 md5 (33)
- navicat导出数据 (34)
- 阿里云acp考试 (33)
- 阿里云 nacos (34)
- redhat官网下载镜像 (36)
- srs服务器 (33)
- pico开发者 (33)
- https的端口号 (34)
- vscode更改主题 (35)
- 阿里云资源池 (34)
- os.path.join (33)
- redis aof rdb 区别 (33)
- 302跳转 (33)
- http method (35)
- js array splice (33)