网关: 用途和产品对比

概述

  • 微服务中的有一个非常关键的组件: API网关

  • 和配置中心一样,在没有采用微服务架构的时候

  • 我们可以自己搭建自己的API网作作为统一的 API 出口和安全验证

  • 在微服务架构之下,服务被拆的非常的零散,在降低了耦合度的同时

  • 也给服务的统一管理增加了难度,就如下边这张图

  • 在旧的服务治理下,像身份验证, 限速, 安全, 日志等等这些通用的功能

  • 需要在每一个服务中单独实现, 这使得系统的维护就没有一个全局的视图来统一的管理这些功能

  • Api 网关致力于解决这些问题,它为微服统一管理这些通用的功能

  • 在此基础上提高系统的可扩展性,看下面这张图

  • 用了微服务之后,搭建上API网关就变成了下面这样

  • 它可以使得服务本身更专注于自己的领域,很好的对服务调用者和服务提供者做了隔离

  • 也就是身份认证,限速,安全,日志,缓存,监控等等,这些都由API网关来做了

  • 而下边的每一个服务,它只需要关心自己的领域,做好自己的服务就可以了

API网关的意义

  • 首先它可以集合多个API, 统一API的入口
    • 既然是微服务,肯定会有很多很多的服务
    • 假如有API网关在调用多个微服务的时候,就只需要调用API网关就可以了
    • 不用关心每一个微服务,它的地址是什么等等
    • 调用的时候只需要告诉API网关, 我要调用哪个微服务就可以
  • 避免内部信息的泄露
    • 因为它对所有的API进行了管控,自然也就避免了泄露
    • 这样下边的服务就不用关心安全问题了,也不用关心自己的敏感信息被暴露的问题
  • 提供安全认证
    • 为服务还提供了安全认证,比如说 sql 注入安全验证等等
    • 权限的控制,也可以在API网关中来做
  • 支持混合的通信协议
    • 一般都会采用 HTTP Restful 等协议
    • 而微服务内部的通信一般会使用 GRPC,AMQP协议等等,它是不统一的
    • 这些一般外部系统也是不支持的,所以需要通过API网关来对外提供API的服务,并且统一协议
  • 降低微服务的复杂度
    • 微服务一般会比单体架构有很大的管理复杂度,比如说令牌的验证,限流等等
    • 假如没有API网关的话,每个微服务都要自己来做这些功能
    • 微服务对外开放后就要考虑安全的问题
    • 微服务引入了API网关之后呢,每个服务就不用关心这些问题
    • 这些问题都放在API网关上来做就行了

API网关弊端

  • 集合增加额外管理和维护成本
    • 首先它需要安装新的中间件
    • 这样也就增加了额外的管理和维护的成本
  • 避免开发时需遵循网关路由规则
    • 开发的时候,指定路由的时候,需要按照api的网关的规则来指定
  • 容易引发单点故障
    • 因为是api网关,所以就会有单一的入口
    • 大家请求都会访问到这个入口
    • 假如API网关出现问题以后,就会导致所有的微服务都不可用了

API 网关产品对比


1 )nginx

  • 它用的比较广泛,它是免费开源的高性能的HTTP服务器和反向代理服务器
  • 同时也是可以用作 API 网关的,它以高性能稳定丰富的功能级简单的配置和资源的消耗闻名
  • Nginx 作为API网关非常的简单,配置也比较简单

2 ) Zuul

  • 它是 SpringCloud中的一个组件,使用非常方便,它提供了一些非常多的功能
  • 比如说,认证,鉴权,限流,动态路由,监控,弹性,安全负载均衡等等
  • 所以用做来做网关是一个非常不错的选择

3 )Kong

  • 它是专注于提供微服务API网关的一个平台
  • 对比,Zuul 只是其中一个组件,而Kong是专注于提供微服务网关,它专门做这个,并且是一个平台
  • 它本身是基于Nginx来实现的, 但是它在Nginx的基础之上,又提供了更方便的配置方式和插件
    • 比如说:验证,日志,限流等等
  • 当需要为应用添加限流功能的时候
    • 因为它只提供了基本的路由功能
    • 开发者需要自己来研发相应的功能,才可以
    • 可能你觉得一个功能还并不麻烦
    • 但是如果在此基础上,今后提出更多的要求,那就比较麻烦了
  • 对于Kong来说,限流功能就是一个插件,只需要简单的配置就可以
  • Kong的插件机制是极高可扩展性的, 可以很方便的为路由和服务提供各种插件
  • 网关所需要的基本特性,它也全部都具备

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/925445.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Java ConcurrentHashMap

Java Map本质不是线程安全的,HashTable和Collections同步包装器(Synchronized Wrapper)在并发场景下性能低。Java还为实现 Map 的线程安全提供了并发包,保证线程安全的方式从synchronize简单方式到精细化,比如Concurre…

Spring 自调用事务失效分析及解决办法

前言 博主在写公司需求的时候,有一个操作涉及到多次对数据库数据的修改。当时就想着要加 Transactional注解来声名事务。并且由于一个方法中有太多行了,于是就想着修改数据库的操作单独提取出来抽象成一个方法。但这个时候,IDEA 提示我自调用…

【LeetCode每日一题】——189.轮转数组

文章目录 一【题目类别】二【题目难度】三【题目编号】四【题目描述】五【题目示例】六【题目提示】七【题目进阶】八【解题思路】九【时空频度】十【代码实现】十一【提交结果】 一【题目类别】 数组 二【题目难度】 中等 三【题目编号】 189.轮转数组 四【题目描述】 …

Spark基本命令详解

文章目录 Spark基本命令详解一、引言二、Spark Core 基本命令1、Transformations(转换操作)1.1、groupBy(func)1.2、filter(func) 2、Actions(动作操作)2.1、distinct([numTasks])2.2、sortBy(func, [ascending], [numTasks]) 三、…

AppFlow:支持飞书机器人调用百炼应用

AppFlow:支持飞书机器人调用百炼应用 简介: 本文介绍了如何创建并配置飞书应用及机器人,包括登录飞书开发者后台创建应用、添加应用能力和API权限,以及通过AppFlow连接流集成阿里云百炼服务,最后详细说明了如何将机器…

基于vite创建一个脚手架(快速入门)

Vite是一种新型的前端构建工具,主要用于构建现代化的Web应用程序。以 原生ESM 方式提供源码。这实际上是让浏览器接管了打包程序的部分工作:Vite 只需要在浏览器请求源码时进行转换并按需提供源码。根据情景动态导入代码,即只在当前屏幕上实际…

学习ASP.NET Core的身份认证(基于Session的身份认证1)

ASP.NET Core使用Session也可以实现身份认证,关于Session的介绍请见参考文献5。基于Session的身份认证大致原理就是用户验证成功后将用户信息保存到Session中,然后在其它控制器中从Session中获取用户信息,用户退出时清空Session数据。百度基于…

视觉语言模型(VLM)学习笔记

目录 应用场景举例 VLM 的总体架构包括: 深度解析:图像编码器的实现 图像编码器:视觉 Transformer 注意力机制 视觉-语言投影器 综合实现 训练及注意事项 总结 应用场景举例 基于文本的图像生成或编辑:你输入 “生成一张…

spider--某站搜索--自动化dp

免责声明:本文仅作分享! 自动化: DrissionPage DrissionPage官网 import time from DrissionPage import ChromiumPage,ChromiumOptions import pandas as pd# 这里配置了浏览器路径,不配置的话直接 page ChromiumPage() co Ch…

学成在线day07

视频处理 技术方案 掌握了xxl-job的分片广播调度方式,下边思考如何分布式去执行学成在线平台中的视频处理任务。 任务添加成功后,对于要处理的任务会添加到待处理任务表中,现在启动多个执行器实例去查询这些待处理任务,此时如何…

vsftpd 的安装和应用(超详细!!!)

FTP(File Transfer Protocol,文件传输协议)是一种用于在计算机网络上进行文件传输的标准协议。它允许用户从一台计算机向另一台计算机上传或下载文件。FTP的工作原理涉及到客户端和服务器之间的交互,以及数据传输的过程。 一、FT…

学习笔记:黑马程序员JavaWeb开发教程(2024.11.29)

10.5 案例-部门管理-新增 如何接收来自前端的数据: 接收到json数据之后,利用RequestBody注解,将前端响应回来的json格式的数据封装到实体类中 对代码中Controller层的优化 发现路径中都有/depts,可以将每个方法对应请求路径中的…

基于Java的小程序电商商城开源设计源码

近年来电商模式的发展越来越成熟,基于 Java 开发的小程序电商商城开源源码,为众多开发者和企业提供了构建个性化电商平台的有力工具。 基于Java的电子商城购物平台小程序的设计在手机上运行,可以实现管理员;首页、个人中心、用户…

JiaJia-CP-1,2,3的WP(1)

一.JiaJia-CP-1 这是ctfshow里电子取证里面的题,以下下是我做题时的WP 审题,最后提交格式要进行md5 加密,给各位CTFer们找了一个md5加密的网站(加紧收藏哦): MD5 在线加密工具 | 菜鸟工具 1.拿到题目&am…

微信小程序下拉刷新与上拉触底的全面教程

微信小程序下拉刷新与上拉触底的全面教程 引言 在微信小程序的开发中,用户体验至关重要。下拉刷新和上拉触底是提高用户交互体验的重要功能,能够让用户轻松获取最新数据和内容。本文将详细介绍这两个功能的实现方式,结合实际案例、代码示例和图片展示,帮助开发者轻松掌握…

Vision Transformer(vit)的主干

图解: 代码: class VisionTransformer(nn.Module):def __init__(self, img_size224, patch_size16, in_c3, num_classes1000,embed_dim768, depth12, num_heads12, mlp_ratio4.0, qkv_biasTrue,qk_scaleNone, representation_sizeNone, distilledFalse,…

无人机的起降装置:探索起飞和降落的秘密 !

一、起降系统的运行方式 起飞方式 垂直起飞:小型无人机通常采用垂直起飞方式,利用螺旋桨产生的升力直接从地面升起。这种方式适用于空间有限或需要快速起飞的场景。 跑道起飞:大型无人机或需要较长起飞距离的无人机,可能会采用…

【VUE3】npm : 无法加载文件 D:\Program\nodejs\node_global\npm.ps1,因为在此系统上禁止运行脚本。

npm : 无法加载文件 D:\Program\nodejs\npm.ps1。未对文件 D:\Program\nodejs\npm.ps1 进行数字签名。无法在当前系统上运行该脚本。有关运行脚本和设置执行策略的详细信息,请参阅 https:/go.microsoft.com/fwlink/?LinkID135170 中的 about_ Execution_Policies。…

跨平台应用开发框架(4)----Qt(系统篇)

目录 1.Qt事件 1.事件来源 2.事件处理 3.按键事件 1.组合按键 4.鼠标事件 1.鼠标单击事件 2.鼠标释放事件 3.鼠标双击事件 4.鼠标移动事件 5.滚轮事件 5.定时器 1.QTimerEvent类 2.QTimer 类 3.获取系统日期及时间 6.事件分发器 7.事件过滤器 2.Qt文件 1.输入…

Mybatis集成篇(一)

Spring 框架集成Mybatis 目前主流Spring框架体系中,可以集成很多第三方框架,方便开发者利用Spring框架机制使用第三方框架的功能。就例如本篇Spring集成Mybatis 简单集成案例: Config配置: Configuration MapperScan(basePack…