Kong与Serverless无服务器计算

首先我们要来科普一下什么是无服务器计算,无服务器计算是在无需最终用户管理的基础设施上托管应用程序的新方式,是IaaS(基础设施即服务)演进的下一个阶段。它将底层基础架构从开发人员中分离出来,基本上虚拟化了运行时(虚拟机的一种,一般指进程级别的虚拟机)和运营管理。这通常被称为 FaaS(功能即服务)。
无服务器计算的优势表现在:敏捷、可伸缩性、计费模式、安全。其他相关知识可以百度,这里我们举个例子来说明一下:比如一款手机游戏,允许用户在不同的平台上查询全球顶级玩家分数表。当请求此信息时,请求从应用程序到API接口。API接口或许会触发某个无服务器函数,这些函数再从数据库表中获取到数据流,返回包含前五名分数的一定格式的数据。一旦构建完成,应用程序的功能就可以在基于移动和基于 web 的游戏版本中重用。这跟设置服务器不同,不是必须要有虚拟机资源或服务器资源,然后等待请求。环境由事件触发,而响应事件所需的逻辑只在响应时执行。这意味着,运行函数的资源只有在函数运行时被创建,产生一种非常高效的方法来构建应用程序。
再举个例子,比如前端调用某个API,实际是去调用后端不同语言的代码来实现相关功能,通过的做法是我们需要部署服务器,安装中间件并将程序部署到中间件中暴露接口以供调用,而无服务器的概念则是在服务器之上再抽象一层,运行时语言、中间件等环境统统封装好,你只需将调用的代码注入到对应的管道,通过触发事件来进行调用,整个程序包含非常多的代码片段及托管(可能是多种语言的),复杂的调用链事件组合,而不再需要诸如服务器部署、环境配置及维护等工作,非常之敏捷。
那么kong网关的无服务器插件究竟有哪些呢,他们运行的机制和原理是什么呢?
1、鼎鼎大名的Aws Lambda,AWS Lambda 是一项计算服务,可使您无需预配置或管理服务器即可运行代码。借助 AWS Lambda,您几乎可以为任何类型的应用程序或后端服务运行代码,并且不必进行任何管理。AWS Lambda 在可用性高的计算基础设施上运行您的代码,执行计算资源的所有管理工作,其中包括服务器和操作系统维护、容量预置和自动扩展、代码监控和记录。您只需要以 AWS Lambda 支持的一种语言提供您的代码。看一下同步调用Lambda的例子:
在这里插入图片描述

实际上对于kong来说,提供的插件可以替换掉上图中的Amazon API Gateway。Kong的管理平台上关于AWS Lambda的配置界面如下:
在这里插入图片描述

由于我没有注册AWS账户,所以没有实际测试,上面的主要参数大致讲解下:
 aws key和secret:这个主要是用来鉴权和认证。
 aws region:亚马逊目前在运营的几个区域,如US区,CN区,这个决定了你的function实际是放在那里。
 aws function name:函数名称,你托管的代码片段函数名,kong在后端服务调用前会去调用aws上预先设置的函数。
 invocation type:调用类型,包含RequestResponse(请求响应)、Event(事件)、Dryrun(空运行、预检) 。
2、微软的无服务器插件 Azure Functions,功能也亚马逊的类似,这里就不再解释。Kong网关的以上两类无服务器插件不仅可以用在全局上、还可以单独作用到服务/路由、以及单个消费方之上,而kong提供的另外两个无服务器插件Pre-function和Post-function则只能作用在全局、服务、路由上,无法作用到单个消费方上。
3、Post-function: kong提供的无服务器函数之一,提供lua的运行环境(因为kong的源码就是lua编写的)。post-function 配置好之后,服务/路由在访问时在配置的其他插件运行之后再运行post-function中配置的函数。
4、Pre-function: kong提供的无服务器函数之一,提供lua的运行环境。pre-function 配置好之后,服务/路由在访问时在配置的其他插件运行之前运行pre-function中配置的函数。这里对他进行重点验证。
网上有个例子:https://www.jianshu.com/p/3496448db28f,是使用curl以文件的方式进行配置,我没尝试成功,自己研读了kong的源码,使用kong的管理平台验证成功,以下为主要过程:
1、 kong源码中有lua的loadstring函数,对提交的function进行验证,如验证不通过,则插件配不上,loadstring函数对于分行代码需要用;来分割。
2、 假设我们要配置的源码如下:
在这里插入图片描述

这个源码是检查调用请求header中的x-custom-auth的值,如果为空则返回401及消息。那么按照1中的要求,写法应该是这样:
local custom_auth = kong.request.get_header(‘x-custom-auth’);if not custom_auth then;return kong.response.exit(401, “Invalid Credentials”);end;kong.service.request.clear_header(‘x-custom-auth’)
3、 通过kong管理平台配置到kong网关中:
在这里插入图片描述
在这里插入图片描述

4、 调用该API的路由,出现我们定义的消息,也就是说pre-function会在所有其他配置的插件之前运行:
在这里插入图片描述

5、 如果我们在请求的消息头中加上x-custom-auth,关闭base-auth和acl插件再次调用,则成功返回消息:
在这里插入图片描述
在这里插入图片描述

最后我们要提一下,为什么网关要来支持这些无服务器运营商和函数呢,第一肯定是为了网关能更加灵活的处理个性化的需求,比如在请求前和请求后做一些常用的诸如数据转换、外部调用、记录、业务计算等功能,另一方面随着serverless的大力发展,未来的趋势也是如此,当大家都在这么做的时候,设计的网关不支持serverless的调用,将会失去优势,这也是kong有先见之明之处。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值