這篇文章將為大家詳細(xì)講解有關(guān)如何深度解讀Serverless架構(gòu)及平臺(tái)選擇,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對相關(guān)知識(shí)有一定的了解。
創(chuàng)新互聯(lián)主營樂陵網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營網(wǎng)站建設(shè)方案,手機(jī)APP定制開發(fā),樂陵h5小程序定制開發(fā)搭建,樂陵網(wǎng)站營銷推廣歡迎樂陵等地區(qū)企業(yè)咨詢
在 Serverless 產(chǎn)品層面,從最早的 AWS Lambda,到 Azure Functions、Goolge Functions、Google CloudRun,再到國內(nèi)阿里云 Serverless Kubernetes、Serverless 應(yīng)用引擎、函數(shù)計(jì)算等,面向計(jì)算的 Serverless 云上基礎(chǔ)設(shè)施越來越豐富。
新概念、新產(chǎn)品的產(chǎn)生不是憑空出現(xiàn),它們誕生之初要解決的是當(dāng)前問題。隨著實(shí)踐者對問題域的理解越來越清晰和深刻,問題的處理方法也會(huì)逐步迭代,更接近問題本質(zhì)的解決方案也會(huì)出現(xiàn)。若不從問題域出發(fā)來理解解決方案,容易陷入兩個(gè)極端,即「它能解決一切問題」和「它太超前了,理解不了」。
圖 1
上圖是一個(gè)常用的項(xiàng)目迭代模型,其目標(biāo)是滿足客戶需求。在這個(gè)模型中,項(xiàng)目組通過 被動(dòng)迭代滿足客戶提出的需求,同時(shí)逐步深刻理解客戶需求的本質(zhì),通過 主動(dòng)迭代和客戶一起采用更好的方案或從根源解決面對的問題。每次的需求反饋會(huì)加深對客戶需求的理解,提供更滿足需求的服務(wù)。每次的 bug 反饋會(huì)加深對處理方案的理解,提供更穩(wěn)定的服務(wù)。
在模型啟動(dòng)后,日常的核心問題就集中在了 如何加速迭代。
如果想要解決迭代加速的問題,就需要了解有哪些制約因素,有的放矢。下述是從開發(fā)視角看到的開發(fā)模型:
圖 2
雖然在實(shí)際應(yīng)用中會(huì)采用不同的開發(fā)語言和架構(gòu),但在每個(gè)階段均有通用的問題,如:
圖3
除了要解決上述通用問題,還需要提供標(biāo)準(zhǔn)化的方案,降低開發(fā)者的學(xué)習(xí)和使用成本,縮短從想法到上線的時(shí)間。
若將上述過程中不同階段花費(fèi)的時(shí)間做個(gè)分析,在項(xiàng)目整個(gè)生命周期中會(huì)發(fā)現(xiàn):
部署&運(yùn)維 占用的時(shí)間和精力,會(huì)遠(yuǎn)大于開發(fā)&測試
通用邏輯占用的時(shí)間和精力,會(huì)接近甚至超過業(yè)務(wù)邏輯
為了加速迭代,需要依次解決占用時(shí)間和精力多的部分,如圖 4 所示:
圖 4
從左至右,通過下放不同層次的運(yùn)維工作,降低「部署&運(yùn)維」成本。在降低了運(yùn)維工作成本后,在「通用邏輯」層面降低成本。二者結(jié)合起來,在迭代過程中更深入聚焦業(yè)務(wù)。該過程也是從 Cloud Hosting 到 Cloud Native 的過程,充分享受云原生帶來的技術(shù)紅利。
由于軟件設(shè)計(jì)架構(gòu)和部署架構(gòu)與當(dāng)時(shí)環(huán)境耦合度高,面對新的理念和服務(wù)、產(chǎn)品,存量應(yīng)用迭代過程中采用的技術(shù)需要有相應(yīng)調(diào)整,即開發(fā)和部署方式需要有一定的改造。對于新應(yīng)用進(jìn)行開發(fā)和部署時(shí),應(yīng)用新的理念有一定的學(xué)習(xí)和實(shí)踐成本。
故上述過程不能一蹴而就,需要根據(jù)業(yè)務(wù)當(dāng)前的痛點(diǎn)優(yōu)先級來選擇匹配的服務(wù)和產(chǎn)品,并根據(jù)未來的規(guī)劃提前進(jìn)行技術(shù)預(yù)研,在不同的階段選擇適合的服務(wù)和產(chǎn)品。
維基百科對于 Serverless 有較為完備的 定義:
Serverless computing is a cloud computing execution model in which the cloud provider runs the server, and dynamically manages the allocation of machine resources. Pricing is based on the actual amount of resources consumed by an application, rather than on pre-purchased units of capacity.
無服務(wù)器計(jì)算是一種云計(jì)算執(zhí)行模型,云廠商提供程序運(yùn)行的服務(wù)器,并動(dòng)態(tài)管理機(jī)器資源的分配。云廠商基于應(yīng)用程序消耗的實(shí)際資源量進(jìn)行定價(jià),而不是用戶預(yù)先購買的容量。
在這種計(jì)算模型下,會(huì)給用戶帶來如下收益:
Serverless computing can simplify the process of deploying code into production. Scaling, capacity planning and maintenance operations may be hidden from the developer or operator. Serverless code can be used in conjunction with code deployed in traditional styles, such as microservices. Alternatively, applications can be written to be purely serverless and use no provisioned servers at all.
無服務(wù)器計(jì)算可以簡化代碼部署到生產(chǎn)環(huán)境的過程,且擴(kuò)縮容、容量規(guī)劃和運(yùn)維操作可以做到對開發(fā)人員透明化。無服務(wù)器代碼可以與以傳統(tǒng)方式(如微服務(wù))部署的代碼結(jié)合使用,或者,開發(fā)者可以按照無服務(wù)器計(jì)算的模式編寫應(yīng)用,完全不用提前配置服務(wù)器.
概念本質(zhì)上是對問題域的抽象,是對問題域特征的總結(jié)。通過特征來理解概念,可以避免注意力集中在文字描述而非概念的價(jià)值本身。
站在用戶角度,我們可以抽象出 Serverless 的如下特征:
免運(yùn)維 (服務(wù)器運(yùn)維、容量管理、彈性伸縮等)
按資源的使用量付費(fèi)
在一定規(guī)模的公司中,若嚴(yán)格區(qū)分開發(fā)和運(yùn)維的角色,這種計(jì)算形態(tài)其實(shí)是已經(jīng)存在的,并非全新的事物。但目前的技術(shù)趨勢,是期望借助云的規(guī)模和技術(shù)紅利優(yōu)勢,通過上云來降低業(yè)務(wù)在技術(shù)側(cè)的成本,并通過技術(shù)紅利反哺業(yè)務(wù)。故業(yè)界對于 Serverless 的討論,注意力是集中在云上的服務(wù)和產(chǎn)品所體現(xiàn)的 Serverless 能力。
Martin Fowler 的 這篇文章站在架構(gòu)的角度,對 Serverless 開發(fā)模型做了充分的闡述,這里做個(gè)簡單的總結(jié),核心圍繞三點(diǎn):
Event-driven 開發(fā)模型
自動(dòng)彈性伸縮
OpenAPI
Serverless 開發(fā)采用 Event-driven 模型,圍繞 HTTP/HTTPS 請求、時(shí)間、消息等 Event 的生產(chǎn)和響應(yīng)進(jìn)行架構(gòu)設(shè)計(jì)。在這樣的模型中,Event 的生產(chǎn)、處理流程是核心,通過 Event 驅(qū)動(dòng)整個(gè)服務(wù)流程,注意力集中在整個(gè)處理流程。對業(yè)務(wù)理解越深刻,Event 類型和業(yè)務(wù)會(huì)越匹配,技術(shù)和業(yè)務(wù)的相互促進(jìn)作用會(huì)越有效。
Event-driven 模型,使得 服務(wù)常駐這種理念從必選項(xiàng)轉(zhuǎn)變?yōu)榭蛇x項(xiàng),可以更好應(yīng)對業(yè)務(wù)請求量的變化,如自動(dòng)彈性伸縮。同時(shí)服務(wù)非常駐,可以降低所需的資源成本和維護(hù)成本,加速項(xiàng)目迭代。
通過 文章的兩幅圖可以更直觀理解:
圖 5
圖 5 是當(dāng)前常見的開發(fā)模型,Click Processor 服務(wù)是個(gè)常駐服務(wù),響應(yīng)來自用戶的所有點(diǎn)擊請求。生產(chǎn)環(huán)境中,通常會(huì)多實(shí)例部署,常駐是個(gè)關(guān)鍵特征,日常的運(yùn)維重點(diǎn)在確保常駐服務(wù)的穩(wěn)定性方面。
圖 6
圖 6 是 Event-driven 開發(fā)模型,關(guān)注重心前移,集中在 Event 的產(chǎn)生和響應(yīng)方面,響應(yīng)服務(wù)是否常駐是個(gè)可選項(xiàng)。
Serverless 在概念上與 PaaS (Platform as a Service)、CaaS (Container as a Service) 的區(qū)別,重點(diǎn)是在是否將 自動(dòng)彈性伸縮作為概念誕生之初的核心特征。
結(jié)合 Event-driven 的開發(fā)模型,Serverless 場景中自動(dòng)彈性伸縮需要對開發(fā)者透明度加深,開發(fā)者開發(fā)過程對處理能力的關(guān)注重心從靜態(tài)轉(zhuǎn)為動(dòng)態(tài),更好應(yīng)對上線后業(yè)務(wù)請求量的不確定性。
在開發(fā)方面,交付時(shí)可以采用鏡像,也可以采用語言層面的打包 (如 Java 中的 war/jar) ,由平臺(tái)負(fù)責(zé)運(yùn)行時(shí)相關(guān)的工作。還可以更進(jìn)一步,采用 FaaS 的理念,依托于平臺(tái)或標(biāo)準(zhǔn)化 FaaS 解決方案,只提供業(yè)務(wù)邏輯函數(shù),由平臺(tái)負(fù)責(zé)請求入口、請求調(diào)用和自動(dòng)彈性伸縮等運(yùn)行時(shí)事宜。
不論哪種交付方式,在云上均可以使用 BaaS 的理念,將部分邏輯通過云平臺(tái)或第三方的 OpenAPI 實(shí)現(xiàn),如權(quán)限管理、中間件管理等,開發(fā)過程中注意力更加聚焦在業(yè)務(wù)層面。
Serverless 服務(wù)模型關(guān)注云廠商對于 Serverless 計(jì)算形態(tài)的支持,不同的服務(wù)和產(chǎn)品形態(tài)主要差異點(diǎn)主要集中在對 Serverless 特征的理解和滿足程度方面:
免運(yùn)維 (服務(wù)器運(yùn)維、容量管理、彈性伸縮等)
按資源的使用量付費(fèi)
在免運(yùn)維維度,最基本的是免去服務(wù)器運(yùn)維成本,開發(fā)者可以按量申請資源。在容量管理、彈性伸縮、流量管理、日志/監(jiān)控/告警等常規(guī)的運(yùn)維層面,不同的服務(wù)和產(chǎn)品會(huì)根據(jù)自身定位、目標(biāo)客戶特征等,有側(cè)重采用適合的方式來滿足。
在計(jì)費(fèi)形態(tài)方面,云廠商一方面會(huì)根據(jù)自身定位確定收費(fèi)維度,如資源、請求量等,一方面也會(huì)根據(jù)當(dāng)前的技術(shù)能力確定收費(fèi)的粒度。
通過上述分析可知,云廠商不同 Serverless 服務(wù)模型不是靜態(tài)的,會(huì)伴隨產(chǎn)品定位、目標(biāo)客戶特征、技術(shù)能力等持續(xù)迭代,和客戶共同成長。
Serverless 服務(wù)模型需要滿足實(shí)際需求,再回到圖 4,云廠商的 Serverless 服務(wù)模型可以分為如下幾類:
資源實(shí)例平臺(tái)
調(diào)度平臺(tái)
應(yīng)用管理平臺(tái)
業(yè)務(wù)邏輯管理平臺(tái)
綜合起來,即:
圖7
目前國內(nèi)外云廠商均提供有不同維度的 Serverless 產(chǎn)品,如下做個(gè)簡單的總結(jié):
圖 8
國外 AWS Fargate / Azure ACI、國內(nèi)阿里云 ECI / 華為 CCI 影響力較大,對用戶提供容器組服務(wù)。容器組作為一個(gè)整體,提供類似 Kubernetes 中 Pod 的概念。用戶可以通過 OpenAPI 調(diào)用直接創(chuàng)建容器組,不用在部署服務(wù)前進(jìn)行服務(wù)器的購買、配置等工作,下放資源相關(guān)的容量管理運(yùn)維工作。用戶可以將資源實(shí)例平臺(tái)作為容量足夠大的資源池使用,在容器組級別進(jìn)行細(xì)粒度的資源申請,配合動(dòng)態(tài)擴(kuò)縮容進(jìn)行應(yīng)用級別的容量管理。
一般在生產(chǎn)環(huán)境中,用戶通常不會(huì)直接使用此類資源管理服務(wù),而是借助應(yīng)用編排服務(wù),將這類服務(wù)透明化,關(guān)注重點(diǎn)放在應(yīng)用編排維度。
Kubernetes 是容器調(diào)度的事實(shí)標(biāo)準(zhǔn),國外 AWS EKS、國內(nèi)阿里云 Serverless Kubernetes 等一方面托管 Kubernetes Master 組件,一方面借助資源管理服務(wù),如 VirtualKubelet + AWS Fargate 或 VirtualKubelet + 阿里云 ECI,提供 Kubernetes Node 層服務(wù)。
對于期望直接使用 Kubernetes 能力,同時(shí)希望低成本運(yùn)維 Kubernetes、不保有資源池的用戶,此類產(chǎn)品比較契合需求。
國外 Google GAE / CloudRun、國內(nèi)阿里云 Serverless 應(yīng)用引擎等進(jìn)一步將運(yùn)維工作服務(wù)化,如發(fā)布管理 (打包/灰度/分批/回滾/版本控制等)、日志/監(jiān)控/告警、流量管理、彈性伸縮等,用戶可以進(jìn)一步專注在業(yè)務(wù)需求,低成本運(yùn)維。
對于期望零成本改造存量應(yīng)用、低學(xué)習(xí)成本使用,又期望最大限度減少運(yùn)維工作的用戶,此類平臺(tái)與需求匹配度較高。但由于應(yīng)用管理層面的運(yùn)維工作在業(yè)界暫無標(biāo)準(zhǔn)化方案,不同的項(xiàng)目會(huì)存在個(gè)性化需求,故采用此類產(chǎn)品過程中需要加強(qiáng)溝通,不斷向平臺(tái)反饋,通過共建的方式磨合 Serverless 平臺(tái)和自身業(yè)務(wù)。
國外 AWS Lambda / Azure Functions / Google Functions、國內(nèi)阿里云函數(shù)計(jì)算 / 騰訊云云函數(shù) / 華為函數(shù)工作流等在應(yīng)用管理的基礎(chǔ)上,進(jìn)一步將開發(fā)過程中的通用邏輯透明化,用戶僅用關(guān)心業(yè)務(wù)邏輯的實(shí)現(xiàn)。這個(gè)過程可以類比開發(fā)過程中的單元測試編寫過程,輸入、輸出是通用的,僅在處理邏輯存在差異。這類 Serverless 產(chǎn)品也是業(yè)界討論最多的形態(tài),代表業(yè)界對于理想的開發(fā)流程的抽象,可以進(jìn)一步加快迭代流程,縮短想法到上線的時(shí)間。這類 Serverless 產(chǎn)品與云平臺(tái)其他類型的產(chǎn)品集成更緊密,以 BaaS 形態(tài)使用云平臺(tái)的服務(wù)實(shí)現(xiàn)通用邏輯,如存儲(chǔ)、緩存等,對云平臺(tái)產(chǎn)品豐富度有一定隱性需求。
處理過程對外部依賴較少或偏計(jì)算類的場景,如前端、多媒體處理處理等,采用此類 Serverless 產(chǎn)品學(xué)習(xí)和使用成本相對低,易于上手。隨著服務(wù)、組件的抽象程度越來越高,會(huì)有越來越多的業(yè)務(wù)場景適用,用戶的運(yùn)維工作會(huì)更為透明化,同時(shí)開發(fā)過程中可以直接享受到業(yè)界的最佳實(shí)踐,服務(wù)的穩(wěn)定性、性能、吞吐等方面借助平臺(tái)的能力做到最大化。
綜上,用戶在進(jìn)行 Serverless 產(chǎn)品選型時(shí),需要先整理當(dāng)前業(yè)務(wù)技術(shù)所處的階段和痛點(diǎn),確定對云上方案的需求,然后再根據(jù)云廠商的產(chǎn)品形態(tài)做對應(yīng),選擇適合當(dāng)前階段的服務(wù)和云產(chǎn)品。
該對應(yīng)關(guān)系重點(diǎn)是了解云產(chǎn)品定位是否可以長期滿足業(yè)務(wù)需求,如:
業(yè)務(wù)技術(shù)目前所處的階段是否與云產(chǎn)品定位匹配
業(yè)務(wù)快速迭代是否會(huì)受限于云產(chǎn)品自身的發(fā)展
云產(chǎn)品的穩(wěn)定如何
云產(chǎn)品是否可以持續(xù)為業(yè)務(wù)帶來技術(shù)紅利
同時(shí)還需要了解云產(chǎn)品是否可以伴隨業(yè)務(wù)發(fā)展,重點(diǎn)是業(yè)務(wù)對技術(shù)的需求中,哪些是云產(chǎn)品層面由于定位帶來的限制,哪些是當(dāng)前云產(chǎn)品的技術(shù)實(shí)現(xiàn)帶來的限制。
若是云產(chǎn)品定位帶來的限制,那么就需要考慮使用和業(yè)務(wù)需求定位更匹配的云產(chǎn)品。若是當(dāng)前技術(shù)實(shí)現(xiàn)的限制,那么有機(jī)會(huì)和云產(chǎn)品共同成長,及時(shí)給云產(chǎn)品反饋,使得云產(chǎn)品可以更好滿足自身的業(yè)務(wù)需求。
除此之外,業(yè)務(wù)層面還需關(guān)注云廠商自身服務(wù)類型的豐富性,云廠商自身服務(wù)越豐富,規(guī)模越大,越會(huì)產(chǎn)生規(guī)模效應(yīng),進(jìn)而給業(yè)務(wù)帶來更豐富的技術(shù)紅利和成本優(yōu)勢。
幸運(yùn)的是,云產(chǎn)品通常都會(huì)有豐富的文檔,也有相應(yīng)的用戶群,可以直面產(chǎn)品經(jīng)理和研發(fā),及時(shí)反饋需求,以共建的理念協(xié)同發(fā)展。
Serverless 本質(zhì)上是一個(gè)問題域,將研發(fā)流程中非業(yè)務(wù)核心卻影響業(yè)務(wù)迭代的問題抽象化,并提出相應(yīng)的解決方案。該概念不是突然產(chǎn)生的,大家或多或少已經(jīng)將其理念應(yīng)用到日常的工作中 ,只是伴隨著云計(jì)算浪潮,云上的 Serverless 服務(wù)和產(chǎn)品更系統(tǒng)、更具有競爭力,可以基于規(guī)模優(yōu)勢和豐富的產(chǎn)品線,面對問題域持續(xù)提供更滿足業(yè)務(wù)需求的服務(wù)。
Serverless 理念不僅在中心化的云端蓬勃發(fā)展,目前也逐步在邊緣端發(fā)展,使得服務(wù)的運(yùn)行更加廣泛化,更好滿足業(yè)務(wù)自身的客戶,提供更低延時(shí)、穩(wěn)定的服務(wù)。
本篇文章嘗試從項(xiàng)目、開發(fā)的日常流程出發(fā),協(xié)助讀者從日常實(shí)踐角度來理解 Serverless 概念,根據(jù)所處的階段選擇適合的 Serverless 服務(wù)和產(chǎn)品。同時(shí)作者本人在阿里云 Serverless 應(yīng)用引擎中負(fù)責(zé)底層研發(fā)工作,嘗試從云產(chǎn)品內(nèi)部的視角,傳遞云產(chǎn)品和用戶共建的觀念,通過協(xié)同更好傳遞和創(chuàng)造價(jià)值。
關(guān)于如何深度解讀Serverless架構(gòu)及平臺(tái)選擇就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。