博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
无服务平台性能比较
阅读量:6591 次
发布时间:2019-06-24

本文共 1013 字,大约阅读时间需要 3 分钟。

大多数主要的云服务供应商都有可以提供功能即服务(FaaS)的平台。最近一些基准测评研究了它们之间在运行时间、冷启动时间、依赖性和资源分配方面的性能区别。

\\

了无服务供应商AWS Lambda、Google Cloud Functions、Azure Functions 和IBM Cloud Functions之间的性能区别。这些测评使用了Node.js功能,尽管展示了不同供应商对请求负载响应的差异,但是这种测试方法所使用的样本太少,而却没有考虑到其他的一些因素,比如底层实例类型,因此受到了。用了不同的。

\\

无服务供应商不仅要考虑CPU、内存和请求数量,还要考虑网络和存储。不同供应商对于如何根据特定的CPU需求来调整内存都存在差异,例如,AWS给配备较高内存的实例。Google也采用了类似的策略,而Azure对于CPU分配的策略则不同,“4-vCPU的虚拟机将分配更多CPU”。

\\

并发请求改变了功能的平均响应时间。对于非并发请求,几乎所有的供应商资源分配都相同,除了Google大约有30%左右的偏差。对于并发请求,当同时执行50个相同的调用,AWS的计算时间增加了46%,Google和Azure分别为7%和3%,IBM为154%。其他的,AWS在并发处理方面有最好的性能表现。

\\

冷启动时间是无服务功能在一段时间没有使用后响应第一个请求所需要的时间。研究结果表明,要维持性能不变对所有的供应商来说都是一个挑战。云供应商一般会不间断地运行一组一般性的worker(即worker pool)。第一个进站的请求获得其中一个实例,该实例负责处理这个请求。实例在处理完第一个请求后保持运行状态。不过,保持运行的时间长短因供应商不同而不同。在他的一篇中说明了Azure的冷启动时间是20分钟,而Google Cloud Functions时间则不定。AWS官方宣布的时间是5分钟,但实际时间更长,因为他们的工程团队进行了调整。当服务需要横向扩展,需要加入新的服务实例时也会发生冷启动。

\\

运行时的选择也会影响性能。Node.js应用程序不需要启动很多CPU,而.NET Core运行时需要更多内存(在AWS Lambda中)。冷启动时间随着分配的内存的增加而减少。测评表明,对于Javascript而言,AWS的冷启动时间最快,之后是GCP和Azure。

\\

查看英文原文

\\

感谢对本文的审校。

转载地址:http://owuio.baihongyu.com/

你可能感兴趣的文章
如何成为高级java程序员
查看>>
洛谷 P1131 BZOJ 1060 [ZJOI2007]时态同步
查看>>
Java中的泛型 --- Java 编程思想
查看>>
javaScript跨浏览器事件处理程序
查看>>
Angular学习笔记
查看>>
WebView 支持 Html5 video 进行全屏播放
查看>>
设计模式 之 中介者模式
查看>>
项目启动之spring篇
查看>>
图像数据增强方法一览(附python代码)
查看>>
socket异步编程--libevent的使用
查看>>
帮你偷懒的靠谱幻灯工具
查看>>
【学习笔记】hive 之行拆列explode
查看>>
【vue】指令修饰符,键盘事件,阻止默认事件,阻止事件传播
查看>>
区块链开发公司浅析区块链技术给保险行业的创新
查看>>
NoSuchMethodError: javax.servlet.ServletContext.getVirtualServerName()Ljava/lang
查看>>
【Linux】CentOS操作和问题汇总
查看>>
nginx负载均衡配置
查看>>
最近重新阅读了逻辑回归,有一些感触
查看>>
数据驱动编程之表驱动法
查看>>
向量的相关运算和几何意义(扫盲篇)
查看>>