[翻譯] 比較 Node.js,Python,Java,C# 和 Go 的 AWS Lambda 性能

来源:https://www.cnblogs.com/Rwing/archive/2018/03/09/comparing-aws-lambda-performance-of-node-js-python-java-csharp-and-go.html
-Advertisement-
Play Games

原文: [Comparing AWS Lambda performance of Node.js, Python, Java, C# and Go](https://read.acloud.guru/comparing-aws-lambda-performance-of-node-js-python... ...


[翻譯] 比較 Node.js,Python,Java,C# 和 Go 的 AWS Lambda 性能

原文: Comparing AWS Lambda performance of Node.js, Python, Java, C# and Go

AWS 最近宣佈他們支持了 C# (Net Core 2.0 版本) 和 Go 語言來實現 Lambda 功能。

(譯者註: AWS Lambda 是 AWS 推出的 Serverless 功能,請參閱這裡或 Serverless 相關資料)

做為一名維護 serverless-golang 項目的工程師,我很想知道每個語言運行時的性能如何,尤其是與其他開發者就此主題深入討論之後。

(譯者註:上圖是 github 上的討論:性能優化是 Lambda 接下來工作會一直持續的事情。每種語言都有他們的長處和弱點, 這就是為什麼我們會有這樣有趣的語言戰爭 :) 此測試只是測量語言運行時啟動時間, 這是動態語言例如 Node.js 和 Python 速度比 C# 和 Java 這樣的靜態語言快的原因, 因為它們缺少類型檢查和依賴項的惰性載入。)

為了找到答案,我使用 Serverless 框架 開發了一系列性能測試,並觀察出了一些非常有趣的結果。

2018 AWS Lambda 性能測試

我的性能測試基於 Yan Cui 2017 年進行的 AWS Lambda 函數的性能測試和比較。為了保持一致性,我 fork 了 Yan 的代碼庫並添加了一些額外的測試模板。

與 Yan 的原始性能測試類似,我們將忽略初始冷啟動時間,僅關註持續時間這一標準,以比較不同語言之間的運行時性能。

所有用於測試的代碼都可以在我的 GitHub 倉庫 中找到。

每個 Lambda 函數都配置了由 Serverless 框架設置的預設 1024MB 記憶體, 並部署到了北弗吉尼亞州(us-east-1)。部署時總共有 12 個 Lambda 函數。

為了管理性能負載測試, 我創建了一個叫 artillery.io 做的腳本。該腳本在一個小時內對所有 12 個 API 執行負載測試:

觀察結果 1 - Net Core 2.0 擁有顯著的提高

.Net Core 2.0 上的 C# 和 F# 都超出了全部預期,並且在平均持續時間內勝過了所有其他運行時。 AWS Lambda 用戶應該將 .Net Core 2.0 設為預設設置,並升級所有仍在使用 1.0 的項目。

請觀察圖上的平均持續時間,.Net Core 2.0 上的 C# 和 F# 在整個 1 小時內始終低於其他運行時:


.Net Core 2.0 上 C# 的平均持續時間

觀察結果 2  —  Go 的性能與 Java 相當

Go 的運行時性能與 Java 非常相似。使用 UPX 壓縮或 Python Shim 沒有顯著的性能提升。

在1小時內,Go 的平均持續時間與 Java 完全相同:


Go 1.x的平均持續時間

觀察結果 3 —  編譯語言與動態語言的性能穩定性

在原來的 2017 年基準測試結果中,與動態語言例如 Python 和 Node.js 相比,Java 和 .Net Core 1.0 這類編譯語言的性能顯然更加穩定。

基於最新的 2018 年性能測試結果,我們觀察到 Java 和新的編譯語言(.Net Core 2.0 和 Go)以及原始動態語言之間沒有太大差異。

性能穩定性,比較平均和最大持續時間

在 2018 年的結果中,我們在所有語言中觀察到了更多的穩定性。可以大膽的推測, 雖然新語言正在添加到 AWS Lambda 中, 但現有的語言不會被遺忘, 而且正在不斷地改進。

觀察結果 4  —  Go 的包體積比 Java 大

使用 -s-w 鏈接器 flag 進行編譯的 Go 二進位文件(2.3mb)會比 Java(2.0mb)體積更大(2.3mb)。通過使用 upx,可以縮小二進位大小,但沒有顯著的改善。

C# 在所有編譯語言中占用的空間最小是 201KB,而 F# 增加了大約 1MB 的額外依賴。

最後的想法

藉助對 Go 和 .Net Core 2.0 支持,AWS 繼續領導了 FaaS 和 Furious 競賽,成為最成熟的提供商,擁有了最廣泛的支持語言。我很高興看到 AWS Lambda 的 .Net Core 2.0 工具的性能和穩定性從早期的 1.0 版本有所改進。

作為 Go 編程語言的倡導者,我仍然覺得 Go 運行時需要一些優化工作。根據性能測試的結果,.Net Core 2.0 比 Go 的執行速度高了 3 倍。

我猜測 .Net Core 2.0 超越 Go 的性能優勢是由於在容器級別進行了一些特定的底層優化以及潛在的 JSON 序列化優化或緩存。雖然對結果感到失望,但我相信隨著 AWS Lambda 平臺持續的快速發展,Go 的性能將會提高。

本性能測試不反映真實的生產用例,最終性能差異非常微妙。然而,與去年相比,架構師和工程師在2018 年考慮 AWS Lambda 功能時應該從所有可用的語言運行時中進行選擇。

讓我在下麵的評論中瞭解你的想法,或直接通過Twitter @yunzhilin與我聯繫。

本文作者 Yun 是 Contino 亞太地區的副總裁,Contino是一家全球咨詢公司,通過現代化的軟體交付使公司組織加速創新。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 使用場景:網站配置項目,為了便於管理,網站有幾個Model類來管理配置文件, 比如ConfigWebsiteModel 用來管理基本信息 ConfigSeoModel 用來管理SEO信息 ConfigCacheModel 用來管理網站緩存信息 不用Model之間不能有重名屬性欄位 現在需要把他們儲存 ...
  • 下麵還有幾句心得大家可以看一下:第一點:【盲目下註】全拼運氣,一把輸了下把倍投,如果連續5把不開,基本腦袋就一片空白了關於PK10下註技巧以及心態沒了清醒的頭腦,你看任何計劃,就算連中20期的計劃你都會慫了,這個時候你就是送財童子了。第二點:【不懂分配金額】沒耐心,心急,一兩把不中,一股腦全壓了,這 ...
  • 前面Insus.NET有在Angularjs實現DropDownList的下拉列表的功能。但是沒有實現怎樣獲取下拉列表的value和text功能。 下麵分別使用ng-click和ng-change來實現。先參考這篇《ASP.NET MVC下使用AngularJs語言(三):ng-options》ht ...
  • 該分頁控制項的顯示邏輯: 1 當前頁面反色突出顯示,鏈接不可點擊 2 第一頁時首頁鏈接不可點擊 3 最後一頁時尾頁鏈接不可點擊 4 當前頁面左右各顯示頁碼可以設置調節,如果左右一樣則居中 5 當左邊頁碼不足時,右側補充 6 當右側頁面不足時左側補充 7 總顯示頁碼數為左側+右側+1(當前) 組成部分: ...
  • 1. 安裝CentOs,可使用最小安裝包鏡像: 2. 跟隨安裝步驟進行,中途要選擇磁碟,如下圖: 3. 設置Root用戶密碼: 4. 安裝完畢後重啟,進入系統,CentOs最小版缺少一些必要組件,首先要打開網卡設置,用 編輯如下文件: 編輯最後一行,將 改為 保存並退出 5. 重啟網卡,然後Ping ...
  • 有沒有想過在.NET中已經有了事件機制,為什麼在WPF中不直接使用.NET事件要加入路由事件來取代事件呢?最直觀的原因就是典型的WPF應用程式使用很多元素關聯和組合起來,是否還記得在WPF自學入門(一)XAM基本知識中提到過兩棵樹,邏輯樹LogicalTree 和可視化樹 VisualTree,那麼 ...
  • 一、業務背景 微信自動退款串接基於酷客多小程式商城系統,為方便財務人員進行訂單退款而開發,將酷客多小程式系統財務退款流程和微信退款系統打通。實現一個系統管理運營。 二、業務流程設計 1.退款單狀態:待退款、退款中、退款完成、自動退款失敗等 2.由於微信申請退款介面接受請求後不會立即進行退款處理,微信 ...
  • ·你為什麼選擇軟體工程專業?你認為你的條件如何?軟工是你喜歡的領域嗎?是你擅長的領域嗎? 當初學軟體是想要做網路游戲的,雖然到了大二也沒能力做。但不得不說軟體工程是一門很好的學科,它不僅僅是大眾普遍認為的編程那麼簡單。 比較嚴謹的說法,軟體工程是研究或應用工程化方法來設計、創造、構建和維護有效、實用 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...