Knative是FaaS的反模式吗?

栏目: 服务器 · Nginx · 发布时间: 5年前

内容简介:Knative在7月份Google Next上发布时,在博客圈引发了一片哗然,然后Riff和Openwhisk采用了它实现自己的FaaS解决方案。从表面上看,它似乎是基于容器即服务(CaaS)解决方案的最佳实践,但对于功能即服务(FaaS)解决方案,可以认为Knative事实上是一个FaaS反模式。在Knative的描述中,它指出它自己是“......构建,部署和管理现代无服务器工作负载”的方式,自Amazon Lambda推出以来,“无服务器”一词与FaaS相关联,说到这一点,重要的是要意识到创建一个无

Knative在7月份Google Next上发布时,在博客圈引发了一片哗然,然后Riff和Openwhisk采用了它实现自己的FaaS解决方案。从表面上看,它似乎是基于容器即服务(CaaS)解决方案的最佳实践,但对于功能即服务(FaaS)解决方案,可以认为Knative事实上是一个FaaS反模式。

在Knative的描述中,它指出它自己是“......构建,部署和管理现代无服务器工作负载”的方式,自Amazon Lambda推出以来,“无服务器”一词与FaaS相关联,说到这一点,重要的是要意识到创建一个无服务器进程或应用程序FaaS解决方案不是必须的,开发人员可以创建通常应用程序容器(例如使用NGINX),如果这些容器启动足够快并且可以在不受影响的情况下可暂停其操作,那么从技术上讲,基于Nginx的这些传统方式也是可以实现无需基于FaaS的无服务器架构。

在CaaS世界中,Knative可以被认为是在Kubernetes上执行自动缩放的正确方法,它解决了scale-to-zero情况,如果你想要正确自动缩放,则需要这样做,它还插入了诸如服务网格(Istio)之类的重要组件,以及执行日志记录和跟踪的能力。简而言之,对于CaaS,它似乎是一种最佳实践。

然而,谈到FaaS,恰恰相反,首先,重要的是要意识到FaaS解决方案有不同的风格。其中两个最重要的是:

1. FaaS解决方案是否有自己的调度器?

2. FaaS解决方案是否需要打包代码放入容器中?

这些问题的答案很重要,因为它从根本上改变了这些FaaS平台的功能,例如,具有自己的调度程序的FaaS解决方案可以:

1. 支持冷/暖/热 lambda池,从而获得更好的性能和日程安排

2. 支持组合函数的流水线优化

3. 在Kubernetes以外的环境中运行

看看Amazon Lambda,Google Cloud Functions和Azure Functions等公共云提供商,他们每个都使用自己单独的调度程序,而且是不依赖于像Kubernetes这样的外部调度器来进行调度的。

类似地,如何打包一个函数的问题很重要,因此不需要将代码打包到容器中有下面好处:

1. 可以快速迭代解决方案,而无需通过完整的CI / CD流程。(即,开发人员的工作效率不受影响)

2. 可以执行管道优化,例如在同一进程空间内以不同语言运行函数。

再次看看公共云提供商的FaaS解决方案,如AWS Lambda,他们部署的artifacts工件不是容器。

如果你看一下公开采用Knative的FaaS解决方案,那就比较弱了,者或缺乏这些能力,作为奖励,这些解决方案会获得比以前更好的扩展解决方案,同时还添加了Istio支持和日志记录集成。

然而,需要在下面两者之间权衡考虑:一个平台是偏重提高开发人员生产力?还是侧重提高应用程序的性能?

我们将再次强调......将代码打包到容器中应该被视为FaaS反模式!正确的方法是让容器以像那些公共FaaS解决方案一样,直接从工件artifact库中提取和执行代码。


以上所述就是小编给大家介绍的《Knative是FaaS的反模式吗?》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

C++ How to Program (5th Edition) (How to Program)

C++ How to Program (5th Edition) (How to Program)

Harvey & Paul) Deitel & Associates / Prentice Hall / 2005-01-05 / USD 98.00

With over 250,000 sold, Harvey and Paul Deitel's C++ How to Program is the world's best-selling introduction to C++ programming. Now, this classic has been thoroughly updated! The Deitels' groundbreak......一起来看看 《C++ How to Program (5th Edition) (How to Program)》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具