AWS Lambda 架構深入探究

AWS Lambda 是現代云架構中最受歡迎的服務之一,因其能夠在完全托管的無服務器環境中運行代碼而廣受認可。然而,盡管 Lambda 廣受歡迎,許多開發者和架構師對它的底層運作機制卻知之甚少,常常將其視為“編寫能夠在云端神奇運行的代碼”的簡單方法。

本文將探討 AWS Lambda 背后的架構,詳細解析它如何以真正的無服務器方式管理實例、配置資源并處理執行。最終,您將全面了解 Lambda 的內部工作原理,從而能夠進行更明智的優化,并在應用程序中更有效地利用它。

Lambda 中的關鍵概念


在討論無服務器和云計算時,務必記住服務器確實在后臺運行。但是,這些服務器完全由云提供商管理—??—這意味著它們負責配置、擴展、安全和隔離。這使得開發者可以專注于他們的應用程序,而無需承擔管理基礎設施的開銷。

讓我們深入了解 Lambda 架構中您需要了解的一些基本概念。

Lambda 運行時


AWS Lambda 通過使用運行時支持多種編程語言。運行時提供特定于語言的環境,用于管理 Lambda 和函數代碼之間調用事件、上下文信息和響應的傳遞。您可以從 AWS 提供的運行時中進行選擇,或者,如果您的應用程序需要不同的環境,您可以靈活地創建自定義運行時。

每個受支持的編程語言的主要版本都帶有唯一的運行時標識符,例如 nodejs20.x 或 python3.13,允許您選擇最適合您應用程序需求的版本。


工作主機和 MicroVM


Lambda 使用工作主機(EC2 Spot 實例)運行,這些主機管理由 Firecracker(我們接下來會討論 Firecracker)構建的眾多 microVM(承載執行環境的虛擬機)。每個 microVM 都專用于單個函數調用,從而確保執行環境的隔離和安全。此外,該架構的設計使得多個工作器主機可以并發處理同一 Lambda 函數的調用。這種設置不僅提供了高可用性和強大的負載均衡,還增強了服務在不同可用區之間的可擴展性和可靠性;


Worker 的最大租約期限為 14 小時。當 Worker 達到最大租約期限時,將不再路由任何調用,MicroVM 將被正常終止,底層 Worker 實例也將終止。Lambda 會持續監控其隊列生命周期內的活動并發出警報。

Firecracker


Firecracker 是驅動所有 Lambda 函數的引擎。它是 Amazon 開發的虛擬化技術,使用 Rust 編寫。

Firecracker 是 Lambda 架構中的一個重要組件。它支持為每個函數調用創建輕量級、安全的 microVM。此機制確保根據 Lambda 函數的需求高效地分配和擴展資源;

Firecracker 在 EC2 Spot 實例內管理 MicroVM,而 Lambda 服務則管理所有工作線程


Lambda 調用


AWS Lambda 提供多種調用方法以滿足各種應用需求,其架構旨在高效支持每種方法。目前為止,我們討論的關鍵概念根據所使用的調用方法以不同的方式運作,并以不同的方式進行交互,從而優化性能和可擴展性。

在深入了解 Lambda 環境中如何處理每個調用之前,讓我們先回顧一下可用的調用類型。

  • 同步調用:通常用于 API 等交互式工作負載。例如,API 網關觸發 Lambda 函數,該函數隨后查詢數據庫并直接響應。此方法即時響應,適用于實時數據處理。
  • 異步調用:用于處理上傳到 S3 的數據等場景。事件觸發由 AWS Lambda 管理的內部隊列,然后該隊列異步處理該函數。此方法非常適合不需要立即響應觸發事件的工作負載。
  • 事件源映射:對于 Kinesis 或 DynamoDB Streams 等流數據服務尤其有用。Lambda 會輪詢這些源,并根據傳入的數據調用相應的函數。此方法能夠高效地進行批處理,對于處理連續數據流的應用程序而言至關重要。

Lambda 通用架構


Lambda 函數的調用方式多種多樣,雖然調用方法會根據觸發它的服務而有所不同,但其核心內部架構保持一致。然而,Lambda 與同步 (Sync) 和異步 (Async) 調用的交互方式有所不同。


每個 Lambda 調用的核心都是前端服務,它是 Lambda 函數的入口點。當 Lambda 函數被調用時,前端服務會管理請求并將其定向到相應的數據平面服務,從而啟動執行流程。

Lambda 函數的調用主要有兩種方式:同步或異步。

  • 同步調用:在同步調用中,前端服務會將請求直接路由到 MicroVM 進行立即處理。
  • 異步調用:對于異步調用,前端服務會將請求放入 Lambda 內部的隊列中。這種內部排隊機制可以有效地將排隊事件分發到可用的 MicroVM 上。隊列通過確保事件的順暢分發,使

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/902493.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/902493.shtml
英文地址,請注明出處:http://en.pswp.cn/news/902493.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Android audio系統五 AudioPolicy 策略配置詳解

引用:Android 音頻策略配置文件解析流程 audio_policy_configuration.xml 是 Android 音頻系統的核心配置文件,它定義了音頻硬件接口、設備路由和基本策略。下面我將詳細介紹這個文件的結構、關鍵配置項和實際應用。audio_policy_configuration.xml 是 …

4.21日學習--引用

引用本質:引用的本質在 c 內部實現是一個指針常量。 代碼中 int& ref a; 可以理解為 int* const ref &a;(指針常量)。 指針常量:指針指向不可變(綁定 a 后,不能再指向其他變量)&…

2.1 數據處理

1. 數據獲取方法 掌握公開數據集的使用、數據質量評估指標、了解常見的網絡爬蟲技術 🧩 一、公開數據集的使用 ? 常見平臺(一定要熟) 平臺簡介示例數據集Hugging Face Datasets專注 NLP、CV 領域的大模型訓練數據集庫IMDB、SQuAD、Common …

Qt QWidget和QML實現窗口拖動源碼分享

一、QWidget實現窗口拖動 .hpp QPoint pressedPoint; bool leftBtnPressed false;.cpp bool PetWidget::eventFilter(QObject *obj, QEvent *event) {if(obj this){if(event->type() QEvent::MouseButtonPress){QMouseEvent* e static_cast<QMouseEvent *>(event)…

在pycharm中搭建yolo11分類檢測系統--PyQt5學習(二)

第二部分 測試本地pycharm通過程序連接遠程服務器autodl 模型的推理需要借助遠程服務器autodl&#xff0c;但是界面的運行是在pycharm中&#xff0c;我的設想是按鈕調用一個py文件就好了。 1. 本地運行PyQt5界面。 2. 當需要載入權重時&#xff0c;通過SSH連接到AutodL服務…

前端框架的“快閃“時代:我們該如何應對技術迭代的洪流?

引言&#xff1a;前端開發者的"框架疲勞" “上周剛學完Vue 3的組合式API&#xff0c;這周SolidJS又火了&#xff1f;”——這恐怕是許多前端開發者2023年的真實心聲。前端框架的迭代速度已經達到了令人目眩的程度&#xff0c;GitHub每日都有新框架誕生&#xff0c;n…

基于YOLO11的遛狗牽繩識別預警系統

基于YOLO11的遛狗牽繩識別預警系統 【包含內容】 【一】項目提供完整源代碼及詳細注釋 【二】系統設計思路與實現說明 【三】預訓練模型與數據集說明 【四】需要列出所有的類別&#xff0c;并且加入識別的類別數量&#xff1a;4類 0: dog (狗) 1: leash (牽引繩) 2: person …

Spring MVC 一個簡單的多文件上傳

原始代碼逐行解釋 PostMapping("/uploads") // ① 聲明處理POST請求&#xff0c;路徑為"/uploads" ResponseBody // ② 直接返回數據到響應體&#xff0c;不進行視圖解析 public String uploads(MultipartFile[] files, // …

C++繼承(最詳細)

目錄 1.繼承的概念以及定義 1.1 繼承的概念 1.2 繼承的定義 ?編輯 2.繼承中的作用域 3.基類和派生類間的轉換 4.派生類的默認成員函數 5.實現不被繼承的類 6.継承與友元 ?編輯 7.繼承與靜態成員 8.多繼承及其菱形繼承問題 8.2 虛繼承 8.3 來看一個小題 9.繼承…

day35圖像處理OpenCV

文章目錄 一、圖像預處理17 直方圖均衡化17.1繪制直方圖17.2直方圖均衡化1. 自適應直方圖均衡化2. 對比度受限的自適應直方圖均衡化3. 示例 19 模板匹配 一、圖像預處理 17 直方圖均衡化 直方圖&#xff1a;反映圖像像素分布的統計圖&#xff0c;橫坐標就是圖像像素的取值&…

【音視頻】FFmpeg內存模型

FFmpeg內存模型 從現有的Packet拷貝一個新Packet的時候&#xff0c;有兩種情況&#xff1a; 兩個Packet的buf引用的是同一數據緩存空間&#xff0c;這時候要注意數據緩存空間的釋放問題&#xff1b;兩個Packet的buf引用不同的數據緩存空間&#xff0c;每個Packet都有數據緩存…

1.2軟考系統架構設計師:系統架構的定義與作用 - 練習題附答案及超詳細解析

系統架構定義與作用綜合知識單選題 題目覆蓋核心概念、發展歷程、設計原則、評估標準及易混淆點&#xff0c;附答案解析&#xff1a; 1. 系統架構的標準定義源自于以下哪個標準&#xff1f; A. ISO/IEC 9126 B. IEEE 1471-2000 C. TOGAF 9.2 D. ITIL v4 答案&#xff1a;B 簡…

go語言對http協議的支持

http&#xff1a;無狀態協議&#xff0c;是互聯網中使用http使用http實現計算機和計算機之間的請求和響應 使用純文本方式發送和接受協議數據&#xff0c;不需要借助專門工具進行分析就知道協議中的數據 服務器端的幾個概念 Request&#xff1a;用戶請求的信息&#xff0c;用…

iscsi服務端安裝及配置

1. 安裝targetcli軟件包 yum install -y targetcli 2. 啟動target服務 systemctl start target systemctl enable target 3. 配置防火墻 firewall-cmd --add-port"3260/tcp" 3. 準備一個物理分區&#xff08;或者邏輯分區&#xff09;…

解決 MongoDB 查詢中的 `InvalidMongoDbApiUsageException` 錯誤

您在使用 Spring Data MongoDB 時遇到了 InvalidMongoDbApiUsageException 異常&#xff0c;錯誤信息如下&#xff1a; “由于 com.mongodb.BasicDocument 的限制&#xff0c;您無法添加第二個 ‘null’ 條件。查詢已經包含 ‘{ “KaTeX parse error: Expected }, got EOF at e…

一個關于相對速度的假想的故事-4

回到公式&#xff0c; 正寫速度疊加和倒寫速度疊加的倒寫相等&#xff0c;這就是這個表達式所要表達的意思。但倒寫疊加用的是減法&#xff0c;而正寫疊加用的是加法。當然是這樣&#xff0c;因為正寫疊加要的是單位時間上完成更遠的距離&#xff0c;而倒寫疊加說的是單位距離需…

重學React(一):描述UI

背景&#xff1a;React現在已經更新到19了&#xff0c;文檔地址也做了全面的更新&#xff0c;上一次系統性的學習還是在16-17的大版本更新。所以&#xff0c;現在就開始重新學習吧&#xff5e; 學習內容&#xff1a; React官網教程&#xff1a;https://zh-hans.react.dev/lea…

AI大模型:(二)2.3 預訓練自己的模型

目錄 1.預訓練原理 2.預訓練范式 1.未標注數據 2.標注數據 3.有正確答案、也有錯誤答案 3.手撕transform模型 3.1.transform模型代碼 3.2.訓練數據集 3.3.預訓練 3.4.推理 4.如何選擇模型

gradle可用的下載地址(免費)

這幾天接手一個老項目&#xff0c;想找gradle老版本的&#xff0c;但一搜&#xff0c;雖然在CSDN上搜索出來一堆&#xff0c;但都是收費&#xff0c;有些甚至要幾十積分(吃相有點難看了)。 我找了一個能訪問的地址&#xff0c;特地分享出來&#xff0c;有需要的自取&#xff01…

vue3新增特性

一、Vue 3 新增特性 1. Composition API 概述: Composition API 提供了一種更靈活和強大的方式來組織和復用邏輯。適用于復雜組件和邏輯復用場景。主要功能: setup 函數:組件的入口點,用于定義響應式數據、方法、生命周期鉤子等。響應式 API:ref 和 reactive 提供更細粒度…