红帽白皮书新鲜出炉!点击获取,让你的云战略更胜一筹! 了解详情
写点什么

AWS Lambda 最新编程语言冷启动时间测试:Node.js 性能最高

  • 2019-09-24
  • 本文字数:1752 字

    阅读完需:约 6 分钟

AWS Lambda最新编程语言冷启动时间测试:Node.js性能最高

本文,作者将比较 AWS 平台上各编程语言的冷启动成绩。随着最近 Ruby 的加入,再加上 2018 年的结果作为参照对象,相信这将是一次有趣的分析。


冷启动是什么?

在无服务器计算世界中,我们要求函数以按需方式运行,并在不需要时被及时弃用。这种仅在必要时运行函数的整个执行过程,即被称为冷启动现象。



定期冷启动(视频截图)


冷启动代表着代码在首次执行时所消耗的时长(一般为 5 到 25 分钟)。这意味着相关代码需要进行下载、容器化、启动以及运行准备。此外,整个过程在语言性能方面存在着巨大差异,不同语言的时耗可能相关 20 到 60 倍。冷启动的长度取决于几个核心变量,例如语言和运行时、专用于函数的资源量(mb)以及所运行函数中的包和依赖关系。


尽管并非随时存在,但冷启动时间仍是一项重要指标。每当我们面对一连串请求流量时,Lambda 函数就有可能出现冷启动操作。

方法

我测试了以下几种语言:Go 1.x、Node.js 8.10、Java 8、Ruby 2.5、Python 3.6 以及.netcore 2.1。分别利用这些语言编写出三个函数,函数本身没有什么实际作用,只是发出“hello world”内容。每种语言的三个函数分别被分配以 128 mb、1024 mb 以及 3008 mb 内存。接下来,我又创建了一个阶梯函数,用以触发这所有 18 个函数,我会定期从 AWS x-ray 处手动收集测试结果。

结果

我收集了冷启动时间,外加 AWS x-ray 引入的新变量——初始化,这项变量用于测量环境设置时间。


下图所示为冷启动成绩对比,共分为三个部分,分别为 128 mb、1024 mb 以及 3008 mb 内存配置下的对应结果。



冷启动时间,128 mb、1024 mb 以及 3008 mb 内存配置下的各函数成绩,单位为毫秒。可以看到,整体结果与 2018 年相同,每种语言分配到的资源量越大、启动时长越短,而经过编译的语言速度相对更慢。


不过令人惊奇的是,与 2018 年不同,这一次,Node.js 成了最大的赢家,紧随其后的分别是 Ruby 以及 Python。在 2018 年的排名中,Python 夺得榜首,我认为这是因为 Lambda 本身就运行在 Python 环境中。由于启动时不需要额外的运行时,所以 Python 获得了明显的优势。而结合新一年的成绩,我们看到其它运行时也迎来了显著优化,甚至足以与 Python 正面对抗。



平均初始化时间,由 AWS x-ray 提供,单位为毫秒。


上图所示为各语言运行时的平均初始化时间。Node.js 再一次与 Python 处于同一水平线,也许是因为 AWS 团队构建了一个针对 Node.js 函数进行优化的独立处理程序?



平均冷启动时间,单位为毫秒


平均冷启动时间的可视化结果,可以看到大多数语言的性能表现都有所提升。与 2018 年不同,今年各种语言似乎都不再高度依赖所能使用的内存资源。当然,除了 Java 和.Net 之外。我很好奇,这是不是代表着 AWS 的工程团队已经找到了无服务器运行效率的上限。


另外,如果在 2020 年再次进行实验,结果又会怎样?我们还会看到如此显著的改善吗?



2018 年平均冷启动时间,单位为毫秒



2019 年平均冷启动时间,单位为毫秒


过去 16 个月,出现了明显的性能改进。事实上,在这样一波全面改进之下,冷启动时间成本已经相当低廉,几乎不需要给予特别关注。Node.js 目前为性能最高的冷启动语言,在短短 16 个月中性能提升达 74.6%,具体缩短了 638 毫秒。



相较于上一年,各语言在同样场景下的冷启动时间都得到显著改善


这确实是对 AWS 工程团队最好的证明。他们不仅开发出了这样的产品,而且一直在努力加以打磨。

温函数

最后,我还打算整理一下关于温函数的性能表现。通过这种方式,我们可以了解 Lambda 函数在大多数情况下的实际执行速度。



温启动,单位为毫秒


经过适当预热的 lambda 函数一直保持着较高运行效率,可以看到各种语言之间的差别已经非常有限。


原文链接:


https://levelup.gitconnected.com/aws-lambda-cold-start-language-comparisons-2019-edition-%EF%B8%8F-1946d32a0244


2019-09-24 09:125410

评论

发布
暂无评论
发现更多内容

【C语言】int 关键字

謓泽

11月月更

这个bug,你中招了吗!!!

石臻臻的杂货铺

kafka 后端 11月月更

Python进阶(五十三)Flask Web开发实现将表单渲染成HTML

No Silver Bullet

Python flask web开发 11月月更

从基础到实战,阿里巴巴高并发系统设计全彩版手册限时开源

Java全栈架构师

程序员 面试 程序员人生 高并发 架构师

Java | IO流缓冲流和转换流

陌上

Java 编程 11月月更

面试中如何才能拿到阿里 P7 的职级?

Java永远的神

Java 阿里巴巴 程序员 架构师 程序员晋升

网络核心笔记(一)

lxmoe

学习笔记 网络 11月月更

三面头条 + 四面阿里 + 五面腾讯拿 offer 分享面经总结

程序知音

java面试 大厂面试 java架构 后端技术 Java面试八股文

一文搞懂MySQL表字段类型长度的含义

海风极客

MySQL 数据库 11月月更

2022全网最全最新Java面试题-独家内部教材

钟奕礼

Java 程序员 java面试 java编程

Java | IO流文件专属流

陌上

Java 编程 11月月更

Java中的String类常用方法

共饮一杯无

Java string 11月月更

Java 后端 100多道面试题,多看点题,没坏处!

钟奕礼

Java 程序员 java面试 java编程

2022成功入职阿里:阿里的三套Java研发岗面试题总结(文末有答案)

钟奕礼

Java java面试 java编程 程序员、

8年Java开发含泪刷题,架构岗现在好难进,有点崩溃

钟奕礼

Java 程序员 java面试 java编程

【Logback+Spring-Aop】实现全面生态化的全链路日志追踪系统服务插件「Logback-MDC篇」

洛神灬殇

log4j logback 全链路追踪 11月日更 MDC

3年Java研发,突击30天,从14K变成了30K

程序知音

Java java面试 大厂面试 java架构 后端技术

2022一线大厂10w字面试总结,每日刷几道,明年金三银四稳了

程序员小毕

spring 程序员 JVM 架构师 java面试

亿级万物互联新时代的物联网消息中间件EMQX调研

宋小生

物联网 mqtt emqx

【LeetCode】无重复字符的最长子串题解

Albert

算法 LeetCode 11月月更

Java | IO流数据流和标准输出流

陌上

Java 编程 11月月更

拿下大厂?这几道jvm面试题必须要懂

钟奕礼

Java 程序员 java面试 java编程

网络核心笔记(二)

lxmoe

学习笔记 网络 11月月更

10道不得不会的 Java容器 面试题

JavaPub

Java 面试 后端

Python冷知识:如何找出新版本增加或删除了哪些标准库?

Python猫

Python

阿里、百度、美团、面试题大集合,愿你更轻松拿下大厂offer

钟奕礼

Java java面试 java编程 程序员、

GitHub标星75k,阿里15W字的Spring高级文档(全彩版),真的太香了

程序知音

Java spring ssm java架构 后端技术

美团技术官手写的精品SpringBoot笔记,涵盖99%知识点,强到离谱

小小怪下士

Java spring 程序员 springboot

集合工具类Collections指南,以及Comparable和Comparator排序详解

共饮一杯无

Java 集合 11月月更

仅hashmap一道面试题我就搞定了面试官成功入职面试官:我裂开了

钟奕礼

Java java面试 java编程 程序员、

10道不得不会的 SpringBoot 面试题

JavaPub

Java 后端 springboot

AWS Lambda最新编程语言冷启动时间测试:Node.js性能最高_语言 & 开发_Nathan Malishev_InfoQ精选文章