0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Serverless 冷啟動(dòng):如何讓函數(shù)計(jì)算更快更強(qiáng)?

jf_81200783 ? 來(lái)源:jf_81200783 ? 作者:jf_81200783 ? 2023-09-06 23:08 ? 次閱讀

問(wèn)題背景

Serverless 計(jì)算也稱(chēng)服務(wù)器無(wú)感知計(jì)算或函數(shù)計(jì)算,是近年來(lái)一種新興的編程模式。其致力于大幅簡(jiǎn)化云業(yè)務(wù)開(kāi)發(fā)流程,使得應(yīng)用開(kāi)發(fā)者從繁雜的服務(wù)器運(yùn)維工作中解放出來(lái)(例如自動(dòng)伸縮、日志和監(jiān)控等)。借助 Serverless 計(jì)算,開(kāi)發(fā)者僅需上傳業(yè)務(wù)代碼并進(jìn)行簡(jiǎn)單的資源配置便可實(shí)現(xiàn)服務(wù)的快速構(gòu)建部署,云服務(wù)商則按照函數(shù)服務(wù)調(diào)用量和實(shí)際資源使用收費(fèi),從而幫助用戶(hù)實(shí)現(xiàn)業(yè)務(wù)的快速交付(fastbuilt&Relia.Deliv.)和低成本運(yùn)行。

然而,Serverless 計(jì)算的無(wú)狀態(tài)函數(shù)編程在帶來(lái)高度彈性和靈活性的同時(shí),也導(dǎo)致了不可避免的冷啟動(dòng)問(wèn)題。由于函數(shù)通常在執(zhí)行完請(qǐng)求后被釋放,當(dāng)請(qǐng)求到達(dá)時(shí),如果沒(méi)有可用實(shí)例則需要從零開(kāi)始啟動(dòng)新的實(shí)例處理請(qǐng)求(即冷啟動(dòng))。當(dāng)冷啟動(dòng)發(fā)生時(shí),Serverless 平臺(tái)需要執(zhí)行實(shí)例調(diào)度、鏡像分發(fā)、實(shí)例創(chuàng)建、資源配置、運(yùn)行環(huán)境初始化以及代碼加載等一系列操作,這一過(guò)程引發(fā)的時(shí)延通??蛇_(dá)請(qǐng)求實(shí)際執(zhí)行時(shí)間的數(shù)倍。相對(duì)于冷啟動(dòng)調(diào)用,熱調(diào)用(即請(qǐng)求到達(dá)時(shí)有可用實(shí)例)的準(zhǔn)備時(shí)間可以控制在亞毫秒級(jí)。在特定領(lǐng)域例如 AI 推理場(chǎng)景,冷啟動(dòng)調(diào)用導(dǎo)致的高時(shí)延問(wèn)題則更為突出,例如,使用 TensorFlow 框架的啟動(dòng)以及讀取和加載模型可能需要消耗數(shù)秒或數(shù)十秒。

wKgaomT3Py6AX8QLAANxG8UqQdQ951.png

因此,如何緩解 Serverless 函數(shù)的冷啟動(dòng)問(wèn)題,改善函數(shù)性能是當(dāng)前 Serverless 領(lǐng)域面臨的主要挑戰(zhàn)之一。

解決方案

從研究思路上看,目前工業(yè)界和學(xué)術(shù)界主要從兩個(gè)方面入手解決冷啟動(dòng)問(wèn)題:

(1)加快實(shí)例啟動(dòng)速度:當(dāng)冷啟動(dòng)調(diào)用發(fā)生時(shí),通過(guò)加速實(shí)例的初始化過(guò)程來(lái)減少啟動(dòng)時(shí)延;

當(dāng)冷啟動(dòng)發(fā)生時(shí),Serverless 平臺(tái)內(nèi)部實(shí)例的初始化過(guò)程可以劃分為準(zhǔn)備和加載兩個(gè)階段。其中,準(zhǔn)備階段主要包括控制面決策調(diào)度/鏡像獲取、Runtime 運(yùn)行時(shí)初始化、應(yīng)用數(shù)據(jù)/代碼傳輸幾個(gè)部分。而加載階段位于實(shí)例內(nèi)部,包括用戶(hù)應(yīng)用框架和代碼的初始化過(guò)程。在工業(yè)界和學(xué)術(shù)界公開(kāi)的研究成果中,針對(duì)實(shí)例啟動(dòng)過(guò)程中的每個(gè)階段都有大量的技術(shù)手段和優(yōu)化方法。如下圖所示,經(jīng)過(guò)優(yōu)化,實(shí)例冷啟動(dòng)的準(zhǔn)備階段和加載階段時(shí)間可被極大得縮短。

wKgZomT3Py-APKKHAAINSvP5RBw082.png

下面列舉了一些近年來(lái)發(fā)表在計(jì)算機(jī)系統(tǒng)領(lǐng)域知名會(huì)議的相關(guān)工作,主要可以分為五個(gè)方面:

1、調(diào)度優(yōu)化/鏡像快速分發(fā)/本地池化:

例如基于樹(shù)結(jié)構(gòu)的跨節(jié)點(diǎn)快速鏡像分發(fā)FaasNet[ATC'21];Pod 池+特化實(shí)例跳過(guò)鏡像傳輸[華為 FunctionGraph]。其中,快速鏡像分發(fā)依賴(lài)于 VM 節(jié)點(diǎn)的上/下行網(wǎng)絡(luò)帶寬,Pod 池特化技術(shù)則是典型的以空間換時(shí)間的做法。

2、輕量級(jí)虛擬化/安全容器:

例如針對(duì)傳統(tǒng)容器 Docker 的精簡(jiǎn)優(yōu)化工作 SOCK[ATC'21];更側(cè)重安全性的輕量級(jí)虛擬化技術(shù)(KataContainers,gVisor 等);基于安全容器的進(jìn)一步的精簡(jiǎn)優(yōu)化工作(Catalyzer[ASPLOS'20],REAP[ASPLOS'21])。通過(guò)裁剪優(yōu)化,安全容器的啟動(dòng)時(shí)延最快可以被壓縮至亞毫秒級(jí)。

3、數(shù)據(jù)共享/跨節(jié)點(diǎn)傳輸優(yōu)化:

例如基于 RDMA 共享內(nèi)存減少跨節(jié)點(diǎn)啟動(dòng)過(guò)程的數(shù)據(jù)拷貝RemoteFork[OSDI'23];或者利用本地代碼緩存跳過(guò)代碼傳輸[華為 FunctionGraph,字節(jié) ByteFaaS 等]?;?RDMA 技術(shù)的跨節(jié)點(diǎn)數(shù)據(jù)傳輸時(shí)延可降低至微妙級(jí)。

4、用戶(hù)代碼精簡(jiǎn)/快速加載:

例如針對(duì) Java 語(yǔ)言的 JVM(JavaVirtualMachine)運(yùn)行時(shí)優(yōu)化技術(shù)[FunctionGraph];以及針對(duì) Python 運(yùn)行時(shí)庫(kù)的裁剪優(yōu)化工作 FaasLight[arxiv'23]。通過(guò)特定的優(yōu)化,JVM 啟動(dòng)時(shí)間可由數(shù)秒降低至數(shù)十毫秒,而 Python 代碼的啟動(dòng)加載時(shí)延可降低約 1/3。

5、其它非容器運(yùn)行時(shí)技術(shù):

例如 WASM(即 WebAssembly)技術(shù)以及針對(duì) WASM 的內(nèi)存隔離方面的優(yōu)化工作 Faasm[ATC'20]。相比容器化技術(shù),直接以進(jìn)程和線程方式組織運(yùn)行函數(shù),可在保證低開(kāi)銷(xiāo)函數(shù)運(yùn)行的同時(shí)具備高度靈活性。

(2)降低冷啟動(dòng)發(fā)生率:通過(guò)函數(shù)預(yù)熱、復(fù)用或?qū)嵗蚕淼确椒ㄌ岣邔?shí)例的利用效率,減少冷啟動(dòng)調(diào)用的發(fā)生

盡管已有的一些實(shí)例啟動(dòng)加速方法已經(jīng)可以將運(yùn)行時(shí)環(huán)境的初始化時(shí)間壓縮至數(shù)十毫秒甚至是數(shù)毫秒,然而用戶(hù)側(cè)的延遲卻仍然存在,例如程序狀態(tài)的恢復(fù),變量或者配置文件的重新初始化,相關(guān)庫(kù)和框架的啟動(dòng)。具體來(lái)講,在機(jī)器學(xué)習(xí)應(yīng)用中,TensorFlow 框架的啟動(dòng)過(guò)程往往需要花費(fèi)數(shù)秒,即使實(shí)例運(yùn)行時(shí)環(huán)境的啟動(dòng)時(shí)間再短,應(yīng)用整體的冷啟動(dòng)時(shí)延對(duì)用戶(hù)而言依然是無(wú)法接受的(注:通常大于 200ms 的時(shí)延可被用戶(hù)察覺(jué))。在這種情況下,可以從另一個(gè)角度入手解決冷啟動(dòng)問(wèn)題,即降低冷啟動(dòng)調(diào)用的發(fā)生率。例如,通過(guò)緩存完整的函數(shù)實(shí)例,請(qǐng)求到達(dá)時(shí)可以快速恢復(fù)并處理請(qǐng)求,從而實(shí)現(xiàn)近乎零的初始化時(shí)延(例如 Dockerunpause 操作時(shí)延小于 0.5ms)。

wKgaomT3Py-ASHWIAADvv2mnULY181.png

降低冷啟動(dòng)發(fā)生率的相關(guān)研究可以分為如下幾個(gè)方面:

1、實(shí)例?;?實(shí)例預(yù)留:

例如基于 Time-to-Live 的 keepalive 保活機(jī)制[AWSLambda,OpenWhisk];或者通過(guò)并發(fā)配置接口預(yù)留一定數(shù)量的實(shí)例[AWSLabmda 等];這些方法原理簡(jiǎn)單,易于實(shí)現(xiàn),但是在面對(duì)負(fù)載變化時(shí)緩存效率較低。

2、基于負(fù)載特征學(xué)習(xí)的動(dòng)態(tài)緩存:

例如基于請(qǐng)求到達(dá)間隔預(yù)測(cè)的動(dòng)態(tài)緩存方案ServerlessintheWild[ASPLOS'20];學(xué)習(xí)長(zhǎng)短期負(fù)載變化特征的動(dòng)態(tài)緩存方案INFless[ASPLOS'22];基于優(yōu)先級(jí)的可替換緩存策略 FaasCache[ATC'21];面向異構(gòu)服務(wù)器集群的低成本緩存方案IceBreaker[ASPLOS'22]。這些動(dòng)態(tài)緩存方案根據(jù)負(fù)載特征學(xué)習(xí)決定實(shí)例緩存數(shù)量或時(shí)長(zhǎng),從而在降低冷啟動(dòng)調(diào)用率的同時(shí)改善緩存資源消耗。

3、優(yōu)化請(qǐng)求分發(fā)提高命中率:

例如兼顧節(jié)點(diǎn)負(fù)載和本地化執(zhí)行的請(qǐng)求調(diào)度算法CH-RLU[HPDC'22]。通過(guò)權(quán)衡節(jié)點(diǎn)負(fù)載壓力和緩存實(shí)例的命中率來(lái)對(duì)請(qǐng)求的分發(fā)規(guī)則進(jìn)行優(yōu)化設(shè)計(jì),避免節(jié)點(diǎn)負(fù)載過(guò)高導(dǎo)致性能下降,同時(shí)兼顧冷啟動(dòng)率。

4、改善并發(fā)/實(shí)例共享或復(fù)用:

例如允許同一函數(shù)工作流的多個(gè)函數(shù)共享 Sandbox 環(huán)境SAND[ATC'18];使用進(jìn)程或線程編排多個(gè)函數(shù)到單個(gè)實(shí)例中運(yùn)行Faastlane[ATC'21];提高實(shí)例并發(fā)處理能力減少實(shí)例創(chuàng)建Fifer[Middle'20];允許租戶(hù)復(fù)用其它函數(shù)的空閑實(shí)例減少冷啟動(dòng)時(shí)間Pagurus[ATC'22]。這些實(shí)例共享或者復(fù)用技術(shù)可以同緩存方案結(jié)合使用,降低冷啟動(dòng)帶來(lái)的性能影響。

總結(jié)

Serverless 的無(wú)狀態(tài)設(shè)計(jì)賦予了函數(shù)計(jì)算高度彈性化的擴(kuò)展能力,然而也帶來(lái)了難以避免的冷啟動(dòng)問(wèn)題。消除 Serverless 函數(shù)的冷啟動(dòng)開(kāi)銷(xiāo)還是從降低函數(shù)冷啟動(dòng)率和加速實(shí)例啟動(dòng)過(guò)程兩個(gè)角度綜合入手。對(duì)于冷啟動(dòng)開(kāi)銷(xiāo)比較大的函數(shù),在函數(shù)計(jì)算框架的設(shè)計(jì)機(jī)制中進(jìn)行優(yōu)化,盡量避免冷啟動(dòng)發(fā)生;當(dāng)冷啟動(dòng)發(fā)生時(shí),采用一系列啟動(dòng)加速技術(shù)來(lái)縮短整個(gè)過(guò)程進(jìn)行補(bǔ)救。在 Serverless 平臺(tái)的內(nèi)部,冷啟動(dòng)的管理在實(shí)踐中可以做進(jìn)一步精細(xì)的劃分,例如針對(duì) VIP 大客戶(hù),針對(duì)有規(guī)律負(fù)載的,或是針對(duì)冷啟動(dòng)開(kāi)銷(xiāo)小的函數(shù),通過(guò)分類(lèi)做定制化、有目的的管理可以進(jìn)一步改善系統(tǒng)效率。

審核編輯 黃宇

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    華為云全域 Serverless 8 月更新盤(pán)點(diǎn)

    CCE Autopilot、Serverless 應(yīng)用托管 CAE、云數(shù)據(jù)倉(cāng)庫(kù) DWS、事件網(wǎng)格 EventGrid 等。華為云函數(shù)工作流 FunctionGraph 一項(xiàng)基于事件驅(qū)動(dòng)的函數(shù)托管
    的頭像 發(fā)表于 09-27 00:06 ?359次閱讀
    華為云全域 <b class='flag-5'>Serverless</b> 8 月更新盤(pán)點(diǎn)

    基于DPU的容器冷啟動(dòng)加速解決方案

    Serverless計(jì)算方式,極大地簡(jiǎn)化了開(kāi)發(fā)人員的工作,使他們能夠?qū)W⒂趹?yīng)用的構(gòu)建與運(yùn)行,而不再需要承擔(dān)服務(wù)器管理的負(fù)擔(dān)。 然而,F(xiàn)aaS模式也并非沒(méi)有缺陷,其中最為人詬病的便是“冷啟動(dòng)”問(wèn)題。所謂
    的頭像 發(fā)表于 09-13 11:50 ?286次閱讀
    基于DPU的容器<b class='flag-5'>冷啟動(dòng)</b>加速解決方案

    bq05504冷啟動(dòng)電壓600mV,在微弱光線下小型太陽(yáng)能板達(dá)不到這么大怎么辦?

    bq05504管理芯片數(shù)據(jù)手冊(cè)顯示冷啟動(dòng)電壓600mV,在微弱光線下小型太陽(yáng)能板達(dá)不到這么大怎么辦,那就是啟動(dòng)不了,那還怎么收集uW級(jí)~mW的電能?
    發(fā)表于 08-13 07:28

    TC3x CAN20在冷啟動(dòng)復(fù)位時(shí)出現(xiàn)MTU故障怎么解決?

    我們觀察到,由于 CAN20 在冷啟動(dòng)復(fù)位時(shí)出現(xiàn)無(wú)法糾正的錯(cuò)誤,MTU 出現(xiàn)故障。 出現(xiàn)此問(wèn)題的原因是冷開(kāi)機(jī)復(fù)位后 RAM 初始化不正常。 有什么具體方法可以初始化 RAM 嗎?
    發(fā)表于 05-29 08:30

    PMP31114.1-適合 3V 冷啟動(dòng)的同步 SEPIC PCB layout 設(shè)計(jì)

    電子發(fā)燒友網(wǎng)站提供《PMP31114.1-適合 3V 冷啟動(dòng)的同步 SEPIC PCB layout 設(shè)計(jì).pdf》資料免費(fèi)下載
    發(fā)表于 05-22 11:28 ?0次下載
    PMP31114.1-適合 3V <b class='flag-5'>冷啟動(dòng)</b>的同步 SEPIC  PCB layout 設(shè)計(jì)

    PMP22063.1-具有熱/冷啟動(dòng)功能的汽車(chē)儀表組和顯示電源 PCB layout 設(shè)計(jì)

    電子發(fā)燒友網(wǎng)站提供《PMP22063.1-具有熱/冷啟動(dòng)功能的汽車(chē)儀表組和顯示電源 PCB layout 設(shè)計(jì).pdf》資料免費(fèi)下載
    發(fā)表于 05-14 14:53 ?0次下載
    PMP22063.1-具有熱/<b class='flag-5'>冷啟動(dòng)</b>功能的汽車(chē)儀表組和顯示電源 PCB layout 設(shè)計(jì)

    設(shè)置應(yīng)用冷啟動(dòng)優(yōu)化案例

    整個(gè)轉(zhuǎn)場(chǎng)過(guò)程不突兀。 應(yīng)用啟動(dòng)概念 對(duì)于應(yīng)用啟動(dòng),首先,引入應(yīng)用啟動(dòng)概念: 冷啟動(dòng):首次打開(kāi)app或者app徹底銷(xiāo)毀后再次打開(kāi)app。 熱啟動(dòng)
    發(fā)表于 04-22 16:31

    華為云 Serverless 應(yīng)用中心:一鍵開(kāi)啟 AI 文生圖新時(shí)代,引領(lǐng)行業(yè)創(chuàng)新浪潮

    隨著數(shù)字化時(shí)代的快速發(fā)展,AI 技術(shù)已成為推動(dòng)行業(yè)創(chuàng)新的關(guān)鍵動(dòng)力。華為云緊跟時(shí)代步伐,全新上線 Serverless 應(yīng)用中心,為用戶(hù)提供海量應(yīng)用模板,實(shí)現(xiàn)一鍵部署函數(shù)和周邊依賴(lài)資源,您輕松擁抱
    的頭像 發(fā)表于 03-19 22:57 ?407次閱讀

    華為云 Serverless 應(yīng)用中心嶄新上線,一鍵部署 AI 文生圖應(yīng)用引領(lǐng)創(chuàng)新潮流

    近日,華為云再次展現(xiàn)其技術(shù)實(shí)力,全新推出了 Serverless 應(yīng)用中心,為用戶(hù)提供了海量的應(yīng)用模板,一鍵部署函數(shù)及關(guān)聯(lián)資源成為現(xiàn)實(shí),極大提升了應(yīng)用的部署效率。無(wú)論是開(kāi)發(fā)者還是運(yùn)維工程師,都可以
    的頭像 發(fā)表于 03-19 22:56 ?462次閱讀
    華為云 <b class='flag-5'>Serverless</b> 應(yīng)用中心嶄新上線,一鍵部署 AI 文生圖應(yīng)用引領(lǐng)創(chuàng)新潮流

    鴻蒙原生應(yīng)用元服務(wù)實(shí)戰(zhàn)-Serverless華為賬戶(hù)認(rèn)證登錄需盡快適配

    一、ArkTS\\\\API9,服務(wù)器端基于serverless開(kāi)發(fā)的應(yīng)用與元服務(wù)華為賬號(hào)注冊(cè)登錄功能暫時(shí)是不支持的 二、3月1日后的審核要求 3月1日的時(shí)間是快到了。 三、會(huì)導(dǎo)致的結(jié)果
    發(fā)表于 02-20 10:14

    GD32 MCU啟動(dòng)后如何運(yùn)行到main函數(shù)

    GD32 MCU啟動(dòng)后如何運(yùn)行到main函數(shù)入口?你是否也有這樣的疑慮。在執(zhí)行到main函數(shù)之前MCU干了哪些事情呢?下面為大家解答。
    的頭像 發(fā)表于 01-15 10:00 ?943次閱讀
    GD32 MCU<b class='flag-5'>啟動(dòng)</b>后如何運(yùn)行到main<b class='flag-5'>函數(shù)</b>

    光譜響應(yīng)函數(shù)如何計(jì)算

    光譜響應(yīng)函數(shù)是描述光譜傳感器對(duì)不同波長(zhǎng)的光的響應(yīng)程度的函數(shù)。在光譜技術(shù)和光學(xué)領(lǐng)域中,光譜響應(yīng)函數(shù)被廣泛應(yīng)用于光譜儀器的校準(zhǔn)、傳感器的設(shè)計(jì)以及光譜數(shù)據(jù)的處理與分析。本文將詳細(xì)介紹光譜響應(yīng)函數(shù)
    的頭像 發(fā)表于 12-19 10:43 ?2339次閱讀

    if函數(shù)如何嵌套計(jì)算公式

    嵌套if函數(shù)可以在Excel等電子表格軟件中實(shí)現(xiàn)復(fù)雜的條件判斷和計(jì)算公式。本文將詳細(xì)介紹if函數(shù)的嵌套使用方法,包括語(yǔ)法、常見(jiàn)應(yīng)用場(chǎng)景和實(shí)例演示等,以及注意事項(xiàng)和進(jìn)階技巧。 一、if函數(shù)
    的頭像 發(fā)表于 11-30 16:55 ?5672次閱讀

    華為云全新上線 Serverless 應(yīng)用中心,支持一鍵構(gòu)建文生圖應(yīng)用

    近日,華為云全新上線 Serverless 應(yīng)用中心,提供大量應(yīng)用模板,幫助用戶(hù)實(shí)現(xiàn)一鍵部署函數(shù)和周邊依賴(lài)資源,節(jié)省部署時(shí)間,快速上手將應(yīng)用部署到華為云函數(shù)工作流 FunctionGraph,并一鍵
    的頭像 發(fā)表于 11-13 09:36 ?545次閱讀
    華為云全新上線 <b class='flag-5'>Serverless</b> 應(yīng)用中心,支持一鍵構(gòu)建文生圖應(yīng)用

    冷啟動(dòng)(Cold boot)流程及階段劃分

    restart--冷啟動(dòng) reset--熱啟動(dòng) ATF冷啟動(dòng)實(shí)現(xiàn)分為5個(gè)步驟: ? BL1 - AP Trusted ROM,一般為BootRom。 ? BL2 - Trusted Boot
    的頭像 發(fā)表于 11-07 15:17 ?1818次閱讀
    <b class='flag-5'>冷啟動(dòng)</b>(Cold boot)流程及階段劃分