内容简介: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的反模式吗?》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 设计模式——订阅模式(观察者模式)
- 设计模式-简单工厂、工厂方法模式、抽象工厂模式
- java23种设计模式-门面模式(外观模式)
- 简单工厂模式、工厂模式、抽象工厂模式的解析-iOS
- Java 设计模式之工厂方法模式与抽象工厂模式
- JAVA设计模式之模板方法模式和建造者模式
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
如何不在网上虚度人生
[美] 肯尼思·戈德史密斯 / 刘畅 / 北京联合出版公司 / 2017-9 / 39.80元
我们平时上网多大程度上是浪费时间,多大程度是在学习、关心社会、激发创造力?我们真能彻底断网,逃离社交网络吗? 手机把都市人变成一群电子僵尸,是福是祸? 浏览记录就是我们将来的回忆录吗?文件归档属于一种现代民间艺术? 不自拍、P图、发朋友圈,我还是我吗? 美国知名概念艺术家戈德史密斯认为:上网绝不是浪费时间,而是一种创造性的活动。在本书中他以跨学科角度、散文式语言进行论证,涉及大众传播学、计算......一起来看看 《如何不在网上虚度人生》 这本书的介绍吧!