首页 > 其他分享 >Kong入门学习实践(1)基础概念快览

Kong入门学习实践(1)基础概念快览

时间:2023-06-11 15:33:06浏览次数:39  
标签:网关 入门 快览 Kong Nginx API kong Gateway

最近在学习Kong网关,因此根据老习惯,我会将我的学习过程记录下来,一来体系化整理,二来作为笔记供将来翻看。由于我司会直接使用Kong企业版,学习过程中我会使用Kong开源版。

什么是Kong?

Kong的原意为金刚,用来形容强健、力量、坚固和稳定,可以想想电影中的金刚,也不难看出Kong的Logo是一只金刚了。

Kong是一款基于Nginx Lua模块写的高可用,易扩展的开源API Gateway项目。由于Kong是基于Nginx的,所以可以水平扩展多个Kong服务器,通过前置的负载均衡配置把请求均匀地分发到各个Server,来应对大批量的网络请求。

相对于纯Nginx ,Kong具有以下优点:

(1)高性能:亚毫秒级处理延迟,可支持关键任务用例和高吞吐量。

(2)可扩展性:可插拔的体系结构,可通过Kong的Plugin SDK扩展 Kong。

(3)可移植性:Kong 可以部署在任何平台、或者云。

NOTE:Kong作为一个优秀的云原生开源项目,目前已经加入了CNCF云原生计算基金会。

Kong要解决啥问题?

其实,Kong要解决的问题也是API网关需要解决的问题,如下图所示:

在没有引入网关之前,为了保障交互的安全,每个服务都需要自己实现一套权限校验(Auth)、日志、限流、监控等方案。这样就不太好,各种成本很高。

引入API网关之后呢,像鉴权、监控、安全、限流、日志、缓存等等方案都可以统一由网关实现。各个服务只需要专注于自己的业务实现就OK,可以帮助其实现敏捷开发,提升团队的迭代效率。

常见的API网关有:OpenResty, Kong, APISIX, Spring Cloud Gateway, Ocelot 等。

Kong有哪些模块?

Kong的具体模块如下图所示:

最下面的两层是:Nginx和OpenResty,它的意思是:kong是一款基于OpenResty (Nginx + Lua) 编写的高可用、易扩展的API Gateway。我们可以直接把Kong理解成是Nginx,但是Kong的功能不止于Nginx。

DataStore层:kong的配置文件可以支持化的存储在NoSQL中,可选:cassandra、postgreSQL。

Plugin层:如果想拓展kong的功能,只需要提供对应的插件就行。有一些现成的插件可以直接用,可以自定义插件。

Restful层:它支持通过Restful API的方式来操作操作和配置Kong(管理nginx的配置文件)。而且kong有专属的dashboard,支持在可视化的界面下和Restful API交互,实现对kong的可视化配置。

Kong的组成架构

Kong的具体组成部分如下图所示:

Kong的流量处理

默认情况下,Kong Gateway在其配置的代理端口8000和8443上监听流量。它评估传入的客户端API请求,并将其路由到适当的后端API。在路由请求和提供响应时,可以根据需要通过插件应用策略。

例如,在路由请求之前,可能需要客户端进行身份验证。这带来了许多好处,包括:

(1)由于Kong Gateway正在处理身份验证,因此该服务不需要自己的身份验证逻辑。

(2)该服务仅接收有效请求,因此不会浪费周期来处理无效请求。

(3)记录所有请求以集中查看流量。

下一篇,我们会通过Docker快速搭建一个Kong API Gateway环境来玩玩。

参考资料

闫观涛,《Kong入门与实践-基于Nginx和OpenRestry的云原生微服务网关》

风起云边,《Kong - Overview》

风一样的程序员,《45张图带你从0玩转Kong Gateway

 

作者:周旭龙

出处:https://edisonchou.cnblogs.com

本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接。

标签:网关,入门,快览,Kong,Nginx,API,kong,Gateway
From: https://www.cnblogs.com/edisonchou/p/edc_kong_learning_notes_chap1.html

相关文章

  • Laravel利用控制器传递参数心得(初始入门)
    2023-06-11 14:29:25有阅读有道云笔记https://note.youdao.com/s/7LhJ27j8 2023年6月9日07时33分44秒近期学习开始学习Laravel,遇到的问题是,如何通过一个blade模板文件,传递参数,并在第二个网页文件中显示出来?此时需要具备弄明白以下基础知识:①已经在搞懂创建控制器phpa......
  • odoo 开发入门教程系列-模型和基本字段
    模型和基本字段在上一章的末尾,我们创建一个odoo模块。然而,此时它仍然是一个空壳,不允许我们存储任何数据。在我们的房地产模块中,我们希望将与房地产相关的信息(名称(name)、描述(description)、价格(price)、居住面积(livingarea)…)存储在数据库中。odoo框架提供了数据库交互的工具......
  • odoo 开发入门教程系列-一个新应用
    一个新应用房地产广告模块假设需要开发一个房地产模块,该模块覆盖未包含在标准模块集中特定业务领域。以下为包含一些广告的主列表视图form视图顶层区域概括了房产的重要信息,比如name,PropertyType,Postcode等等。列表记录详情页中,第一个tab包含了房产的描述信息,比如:bedrooms,Livi......
  • Tomcat 入门实战(1)--简介
    Tomcat是Apache软件基金会(ApacheSoftwareFoundation)的一个开源项目,实现了Servlet及JSP规范,可以用来部署WEB应用及WebService;本文主要介绍其基本概念。1、Tomcat安装安装Tomcat之前需要先安装Java,并设置$JAVA_HOME环境变量,Linuxbash环境下可按如下方式设置:expor......
  • Java入门(一) 基本的Java程序设计
    (基本的Java程序设计)一、一个简单的Java程序1.1最简单的程序下面是一个最基本的Java程序:publicclassFirstSample{publicstaticvoidmain(String[]args){System.out.println("helloworld");}}这个程序非常的简单,但所有的Java都有这样的结构。在......
  • Zookeeper入门实战(5)-分布式锁
    在分布式环境中,当需要控制对某一资源的不同进程并发访问时就需要使用分布式锁;可以使用 ZooKeeper+Curator来实现分布式锁,本文主要介绍 Curator中分布式锁的使用,文中所使用到的软件版本:Java1.8.0_341、Zookeeper3.7.1、curator5.4.0。1、引入依赖<dependency><gro......
  • WPF入门教程系列二十八 ——DataGrid使用示例MVVM模式(5)
    WPF入门教程系列目录WPF入门教程系列二——Application介绍WPF入门教程系列三——Application介绍(续)WPF入门教程系列四——Dispatcher介绍WPF入门教程系列五——Window介绍WPF入门教程系列十一——依赖属性(一)WPF入门教程系列十五——WPF中的数据绑定(一)  添加Cl......
  • Vue入门实战05-模板语法
    Vue使用一种基于HTML的模板语法,声明式将其组件实例的数据绑定到DOM。所有Vue模板都是语法层合法的HTML,可被符合规范的浏览器和HTML解析器解析。底层机制中,Vue会将模板编译成高度优化的JavaScript代码。结合响应式系统,当应用状态变更时,Vue能够智能地推导出需要重新渲染的......
  • 矩阵乘法与动态 DP 入门
    矩阵乘法及广义矩阵乘法前置知识:矩阵相关基础概念。记\(A(i,j)\)表示矩阵\(A\)的第\(i\)行第\(j\)列,\(n_A\)为\(A\)的行数,\(m_A\)为\(A\)的列数。定义矩阵加法\(A+B\)为(\(n_A=n_B,m_A=m_B\)):\[\\\\\[A+B](i,j)=A(i,j)+B(i,j)\]矩阵加法有交换律,结合......
  • java——微服务——spring cloud——Nacos——Nacos快速入门
            父工程中新增依赖:          ==================================================================================        客户端依赖修改——userservice和orderservice两个修改       ......