Serverless computing has seen a myriad of work exploring its potential. Some systems tackle Function-as-a-Service (FaaS) properties on automatic elasticity and scale to run highly-parallel computing jobs. However, they focus on specific platforms and convey that their ideas can be extrapolated to any FaaS runtime. An important question arises: do all FaaS platforms fit parallel computations? In this paper, we argue that not all of them provide the necessary means to host highly-parallel applications. To validate our hypothesis, we create a comparative framework and categorize the architectures of four cloud FaaS offerings, emphasizing parallel performance. We attest and extend this description with an empirical experiment that consists in plotting in deep detail the evolution of a parallel computing job on each service. The analysis of our results evinces that FaaS is not inherently good for parallel computations and architectural differences across platforms are decisive to categorize their performance. A key insight is the importance of virtualization technologies and the scheduling approach of FaaS platforms. Parallelism improves with lighter virtualization and proactive scheduling due to finer resource allocation and faster elasticity. This causes some platforms like AWS and IBM to perform well for highly-parallel computations, while others such as Azure present difficulties to achieve the required parallelism degree. Consequently, the information in this paper becomes of special interest to help users choose the most adequate infrastructure for their parallel applications.
翻译:没有服务器的计算已经看到许多探索其潜力的工作。 一些系统在自动弹性和规模上处理“ 功能为服务” 属性, 以自动弹性和规模处理“ 功能为服务” 属性, 以运行高度平行的计算工作。 但是, 它们关注特定平台, 并传达它们的想法可以外推到任何 FaaS 运行时间。 一个重要问题是: 所有 FaaS 平台是否都适合平行计算? 在本文中, 我们争辩说, 它们并非都提供了容纳高度平行应用程序的必要手段。 为了验证我们的假设, 我们建立了一个比较框架, 并将四个云为FaS 提供的架构分类, 强调平行的性能。 我们证明并扩展了这一描述, 实验性实验性实验性实验包括深度规划每个服务的平行计算工作的演变过程。 对我们的研究结果的分析表明, FaaS 平台是否在平行的计算和结构差异中都适合平行的计算? 我们的论点是, 它们并非都决定了它们的业绩。 一个关键的洞察力是虚拟化技术的重要性和FaS 平台的时间安排方法。 平行性改进了某些较轻的虚拟化和主动性特别性安排, 因为有些特殊的虚拟化的虚拟化和时间表, 例如精细的资源分配和快速化的软件化的软件化的软件化, 从而可以产生这样的快速化和快速的系统, 快速化的计算, 和快速化的计算, 快速化的磁性化的模型化的操作性, 从而使得成为了这种系统成为高度的磁性, 和快速的逻辑化的操作性, 从而产生这样的系统。