深入剖析网关gateway原理

 更新时间:2021年08月27日 17:45:05   作者:没伞的孩子努力奔跑  
这篇文章主要介绍了网关gateway,本文从网关的背景开始讲起,一次论述网关的依赖,负载均衡,网关的选型等等进行深入的剖细,让大家可以更深一步的了解

一 背景

微服务架构提供一种简单有效的统一的 API入口

负责服务请求路由、组合及协议转换,并且基于 Filter 链的方式提供了权限认证,监控、限流等功能。

  • 优点:

性能强劲:是第一代网关Zuul的1.6倍。

功能强大:内置了很多实用的功能,例如转发、监控、限流等设计优雅,容易扩展。

  • 缺点:

依赖Netty与WebFlux(Spring5.0),不是传统的Servlet编程模型(Spring MVC就是基于此模型实现),学习成本高。需要Spring Boot 2.0及以上的版本,才支持

二需要的依赖:

 <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-gateway</artifactId>
        </dependency>

   添加配置文件及说明:

server:
port: 9000
spring:
application:
name: sca-gateway
cloud:
gateway:
routes: #配置网关路由规则
- id: route01  #路由id,自己指定一个唯一值即可
uri: http://localhost:8081/ #网关帮我们转发的url
predicates: ###断言(谓此):匹配请求规则
- Path=/nacos/provider/echo/**  #请求路径定义,此路径对应uri中的资源
filters: ##网关过滤器,用于对谓词中的内容进行判断分析以及处理
- StripPrefix=1 #转发之前去掉path中第一层路径,例如nacos
 

说明

路由(Route) 是 gateway 中最基本的组件之一

表示一个具体的路由信息载体。

主要定义了下面的几个信息:

id,路由标识符,区别于其他 Route。

uri,路由指向的目的地 uri,即客户端请求最终被转发到的微服务。

predicate,断言(谓词)的作用是进行条件判断,只有断言都返回真,才会执行路由。

filter,过滤器用于修改请求和响应信息。

什么是网关?

服务访问(流量)的一个入口,类似生活中的“海关“

为什么使用网关?

服务安全,统一服务入口管理,负载均衡,限流,鉴权

Spring Cloud Gateway 应用的初始构建过程(添加依赖,配置

Gateway 服务的启动底层是通过谁去实现的?

Netty网络编程框架-ServerSocket

Gateway 服务做请求转发时一定要在注册中心进行注册吗?

不一定,可以直接通过远端url进行服务访问

三  负载均衡

需要的porm文件是nacos的配置和包,是通过nacos配置中心,寻找实例。

网关层面是如何实现负载均衡的?

通过服务名去查找具体的服务实例

网关层面是如何通过服务名查找服务实例的?

Ribbon

你了解Ribbon中的哪些负载均衡算法?

轮询,权重,hash,……可通过IRule接口进行查看分析

网关进行请求转发的流程是怎样,有哪些关键对象?

XxxHandlerMapping,Handler,。。。

网关层面服务的映射方式怎样的?

谓词-path,…,服务名/服务实例

网关层如何记录服务的映射?

通过map,并要考虑读写锁的应用

下图是定义在网关层面定义全局过滤器

网关(Gateway)

诞生的背景?

第一:统一微服务访问的入口,

第二:对系统服务进行保护,

第三进行统一的认证,授权,限流

网关的选型?

Netifix Zuul,Spring Cloud Gateway,…

Spring Cloud Gateway的入门实现

添加依赖,路由配置,启动类

Spring Cloud Gateway中的负载均衡?

网关服务注册,服务的发现,基于uri:lb://服务id方式访问具体服务实例

Spring Cloud Gateway中的断言配置?

掌握常用几个就可,用时可以通过搜索引擎去查

Spring Cloud Gateway中的过滤器配置?

掌握过滤器中的两大类型-局部和全局

Spring Cloud Gateway中的限流设计?

Sentinel

Gateway在互联网架构中的位置?

nginx->gateway–>微服务–>微服务

Gateway底层负载均衡的实现?

Ribbon

Gateway应用过程中设计的主要概念?

路由id,路由uri,断言,过滤器

Gateway中你做过哪些断言配置?

after,header,path,cookie,…

Gateway中你用的过滤器有哪些?

添加前缀,去掉前缀,添加请求头,…,负载均衡,…

以上就是深入理解网关gateway的详细内容,更多关于网关gateway的资料请关注脚本之家其它相关文章!

相关文章

  • github版本库使用详细图文教程(命令行及图形界面版)

    github版本库使用详细图文教程(命令行及图形界面版)

    今天我们就来学习github的使用,我们将用它来管理我们的代码,你会发现它的好处的,当然是要在本系列教程全部完成之后,所以请紧跟站长的步伐,今天是第一天,我们来学习如何在git上建立自己的版本仓库,并将代码上传到仓库中
    2015-08-08
  • Git的基本操作流程及工作区版本库暂存区的关系

    Git的基本操作流程及工作区版本库暂存区的关系

    这篇文章主要为大家介绍了Git的基本操作流程及工作区版本库暂存区的关系,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-04-04
  • 使用 tke-autoscaling-placeholder 实现秒级弹性伸缩的方法

    使用 tke-autoscaling-placeholder 实现秒级弹性伸缩的方法

    这篇文章主要介绍了使用 tke-autoscaling-placeholder 实现秒级弹性伸缩的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-01-01
  • 二维码的生成细节和原理

    二维码的生成细节和原理

    本篇文章主要介绍二维码,二维码大家都很熟悉,但是二维码是如何生成的并不了解,对二维码感兴趣的小伙伴可以看下本篇文章
    2016-07-07
  • 一张图告诉你计算机编程语言的发展历史

    一张图告诉你计算机编程语言的发展历史

    这篇文章主要介绍了一张图告诉你计算机编程语言的发展历史,也可看作是计算机的发展历史大事记,需要的朋友可以参考下
    2015-07-07
  • OAuth从1.0到2.1的发展之路

    OAuth从1.0到2.1的发展之路

    OAUTH协议为用户资源的授权提供了一个安全的、开放而又简易的标准。简单来说就是提供除了"账户密码"验证方式以外的验证授权方式。这篇文章介绍了OAuth从1.0到2.1的发展之路,感兴趣的同学可以收藏一下
    2021-11-11
  • UE、UI、UCD、Interaction Design、UED、UX、HCI、Usability,IA

    UE、UI、UCD、Interaction Design、UED、UX、HCI、Usability,IA

    最近,总是缠绵在UE、UI、UCD、Interaction Design、UED、UX、HCI、Usability,IA等等名词间,我一边搜集,一边整理,现在放在一次统一解释,以便比较,以正视听。很多地方未必准确,欢迎提出修改意见。
    2009-04-04
  • 数据分析2020年全国各省高考成绩分布情况

    数据分析2020年全国各省高考成绩分布情况

    这篇文章主要介绍了数据分析2020年全国各省高考成绩分布情况,顺便可以用这个数据看每个省市的一本线划分比率,还有其他相关的数据,需要的朋友可以参考下
    2020-07-07
  • 在linux服务器本地部署Deepseek及在mac远程web-ui访问的操作

    在linux服务器本地部署Deepseek及在mac远程web-ui访问的操作

    文章介绍了在Linux服务器上部署和使用DeepSeek模型的步骤,包括安装Ollama、下载和运行模型,以及在Linux服务器上配置Ollama服务以实现远程访问,接着,文章介绍了在Mac上安装WebUI工具OpenWebUI,以便更方便地与远程Linux服务器上的DeepSeek模型进行交互
    2025-02-02
  • 一文读懂吞吐量(TPS)、QPS、并发数、响应时间(RT)概念

    一文读懂吞吐量(TPS)、QPS、并发数、响应时间(RT)概念

    这篇文章主要介绍了吞吐量(TPS)、QPS、并发数、响应时间(RT)概念,在开发中需要先搞懂这些基础知识,才能更好运用,需要的朋友可以参考下
    2020-07-07

最新评论